github.com/apremalal/vamps-core@v1.0.1-0.20161221121535-d430b56ec174/server/webapps/apiexplorer/swagger-ui.js (about) 1 /** 2 * swagger-ui - Swagger UI is a dependency-free collection of HTML, JavaScript, and CSS assets that dynamically generate beautiful documentation from a Swagger-compliant API 3 * @version v2.1.4 4 * @link http://swagger.io 5 * @license Apache-2.0 6 */ 7 (function(){this["Handlebars"] = this["Handlebars"] || {}; 8 this["Handlebars"]["templates"] = this["Handlebars"]["templates"] || {}; 9 this["Handlebars"]["templates"]["apikey_button_view"] = Handlebars.template({"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 10 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 11 return "<!--div class='auth_button' id='apikey_button'><img class='auth_icon' alt='apply api key' src='images/apikey.jpeg'></div-->\n<div class='auth_container' id='apikey_container'>\n <div class='key_input_container'>\n <div class='auth_label'><label for='input_apiKey_entry'>" 12 + escapeExpression(((helper = (helper = helpers.keyName || (depth0 != null ? depth0.keyName : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"keyName","hash":{},"data":data}) : helper))) 13 + "</label></div>\n <input placeholder='api_key' class='auth_input' id='input_apiKey_entry' name='apiKey' type='text'/>\n <div class='auth_submit'><a class='auth_submit_button' id='apply_api_key' href='#' data-sw-translate>apply</a></div>\n </div>\n</div>\n"; 14 },"useData":true}); 15 this["Handlebars"]["templates"]["basic_auth_button_view"] = Handlebars.template({"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 16 return "<div class='auth_button' id='basic_auth_button'><img class='auth_icon' src='images/password.jpeg'></div>\n<div class='auth_container' id='basic_auth_container'>\n <div class='key_input_container'>\n <div class=\"auth_label\"><label for=\"input_username\" data-sw-translate>Username</label></div>\n <input placeholder=\"username\" class=\"auth_input\" id=\"input_username\" name=\"username\" type=\"text\"/>\n <div class=\"auth_label\"><label for=\"password\" data-sw-translate>Password</label></div>\n <input placeholder=\"password\" class=\"auth_input\" id=\"input_password\" name=\"password\" type=\"password\"/>\n <div class='auth_submit'><a class='auth_submit_button' id=\"apply_basic_auth\" href=\"#\">apply</a></div>\n </div>\n</div>\n\n"; 17 },"useData":true}); 18 this["Handlebars"]["templates"]["content_type"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 19 var stack1, buffer = ""; 20 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.produces : depth0), {"name":"each","hash":{},"fn":this.program(2, data),"inverse":this.noop,"data":data}); 21 if (stack1 != null) { buffer += stack1; } 22 return buffer; 23 },"2":function(depth0,helpers,partials,data) { 24 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression, buffer = " <option value=\"" 25 + escapeExpression(lambda(depth0, depth0)) 26 + "\">"; 27 stack1 = lambda(depth0, depth0); 28 if (stack1 != null) { buffer += stack1; } 29 return buffer + "</option>\n"; 30 },"4":function(depth0,helpers,partials,data) { 31 return " <option value=\"application/json\">application/json</option>\n"; 32 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 33 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<label data-sw-translate for=\"" 34 + escapeExpression(((helper = (helper = helpers.contentTypeId || (depth0 != null ? depth0.contentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"contentTypeId","hash":{},"data":data}) : helper))) 35 + "\">Response Content Type</label>\n<select name=\"contentType\" id=\"" 36 + escapeExpression(((helper = (helper = helpers.contentTypeId || (depth0 != null ? depth0.contentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"contentTypeId","hash":{},"data":data}) : helper))) 37 + "\">\n"; 38 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.produces : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(4, data),"data":data}); 39 if (stack1 != null) { buffer += stack1; } 40 return buffer + "</select>\n"; 41 },"useData":true}); 42 'use strict'; 43 44 45 $(function() { 46 47 // Helper function for vertically aligning DOM elements 48 // http://www.seodenver.com/simple-vertical-align-plugin-for-jquery/ 49 $.fn.vAlign = function() { 50 return this.each(function(){ 51 var ah = $(this).height(); 52 var ph = $(this).parent().height(); 53 var mh = (ph - ah) / 2; 54 $(this).css('margin-top', mh); 55 }); 56 }; 57 58 $.fn.stretchFormtasticInputWidthToParent = function() { 59 return this.each(function(){ 60 var p_width = $(this).closest("form").innerWidth(); 61 var p_padding = parseInt($(this).closest("form").css('padding-left') ,10) + parseInt($(this).closest('form').css('padding-right'), 10); 62 var this_padding = parseInt($(this).css('padding-left'), 10) + parseInt($(this).css('padding-right'), 10); 63 $(this).css('width', p_width - p_padding - this_padding); 64 }); 65 }; 66 67 $('form.formtastic li.string input, form.formtastic textarea').stretchFormtasticInputWidthToParent(); 68 69 // Vertically center these paragraphs 70 // Parent may need a min-height for this to work.. 71 $('ul.downplayed li div.content p').vAlign(); 72 73 // When a sandbox form is submitted.. 74 $("form.sandbox").submit(function(){ 75 76 var error_free = true; 77 78 // Cycle through the forms required inputs 79 $(this).find("input.required").each(function() { 80 81 // Remove any existing error styles from the input 82 $(this).removeClass('error'); 83 84 // Tack the error style on if the input is empty.. 85 if ($(this).val() === '') { 86 $(this).addClass('error'); 87 $(this).wiggle(); 88 error_free = false; 89 } 90 91 }); 92 93 return error_free; 94 }); 95 96 }); 97 98 function clippyCopiedCallback() { 99 $('#api_key_copied').fadeIn().delay(1000).fadeOut(); 100 101 // var b = $("#clippy_tooltip_" + a); 102 // b.length != 0 && (b.attr("title", "copied!").trigger("tipsy.reload"), setTimeout(function() { 103 // b.attr("title", "copy to clipboard") 104 // }, 105 // 500)) 106 } 107 108 // Logging function that accounts for browsers that don't have window.console 109 function log(){ 110 log.history = log.history || []; 111 log.history.push(arguments); 112 if(this.console){ 113 console.log( Array.prototype.slice.call(arguments)[0] ); 114 } 115 } 116 117 // Handle browsers that do console incorrectly (IE9 and below, see http://stackoverflow.com/a/5539378/7913) 118 if (Function.prototype.bind && console && typeof console.log === "object") { 119 [ 120 "log","info","warn","error","assert","dir","clear","profile","profileEnd" 121 ].forEach(function (method) { 122 console[method] = this.bind(console[method], console); 123 }, Function.prototype.call); 124 } 125 126 window.Docs = { 127 128 shebang: function() { 129 130 // If shebang has an operation nickname in it.. 131 // e.g. /docs/#!/words/get_search 132 var fragments = $.param.fragment().split('/'); 133 fragments.shift(); // get rid of the bang 134 135 switch (fragments.length) { 136 case 1: 137 if (fragments[0].length > 0) { // prevent matching "#/" 138 // Expand all operations for the resource and scroll to it 139 var dom_id = 'resource_' + fragments[0]; 140 141 Docs.expandEndpointListForResource(fragments[0]); 142 $("#"+dom_id).slideto({highlight: false}); 143 } 144 break; 145 case 2: 146 // Refer to the endpoint DOM element, e.g. #words_get_search 147 148 // Expand Resource 149 Docs.expandEndpointListForResource(fragments[0]); 150 $("#"+dom_id).slideto({highlight: false}); 151 152 // Expand operation 153 var li_dom_id = fragments.join('_'); 154 var li_content_dom_id = li_dom_id + "_content"; 155 156 157 Docs.expandOperation($('#'+li_content_dom_id)); 158 $('#'+li_dom_id).slideto({highlight: false}); 159 break; 160 } 161 }, 162 163 toggleEndpointListForResource: function(resource) { 164 var elem = $('li#resource_' + Docs.escapeResourceName(resource) + ' ul.endpoints'); 165 if (elem.is(':visible')) { 166 $.bbq.pushState('#/', 2); 167 Docs.collapseEndpointListForResource(resource); 168 } else { 169 $.bbq.pushState('#/' + resource, 2); 170 Docs.expandEndpointListForResource(resource); 171 } 172 }, 173 174 // Expand resource 175 expandEndpointListForResource: function(resource) { 176 var resource = Docs.escapeResourceName(resource); 177 if (resource == '') { 178 $('.resource ul.endpoints').slideDown(); 179 return; 180 } 181 182 $('li#resource_' + resource).addClass('active'); 183 184 var elem = $('li#resource_' + resource + ' ul.endpoints'); 185 elem.slideDown(); 186 }, 187 188 // Collapse resource and mark as explicitly closed 189 collapseEndpointListForResource: function(resource) { 190 var resource = Docs.escapeResourceName(resource); 191 if (resource == '') { 192 $('.resource ul.endpoints').slideUp(); 193 return; 194 } 195 196 $('li#resource_' + resource).removeClass('active'); 197 198 var elem = $('li#resource_' + resource + ' ul.endpoints'); 199 elem.slideUp(); 200 }, 201 202 expandOperationsForResource: function(resource) { 203 // Make sure the resource container is open.. 204 Docs.expandEndpointListForResource(resource); 205 206 if (resource == '') { 207 $('.resource ul.endpoints li.operation div.content').slideDown(); 208 return; 209 } 210 211 $('li#resource_' + Docs.escapeResourceName(resource) + ' li.operation div.content').each(function() { 212 Docs.expandOperation($(this)); 213 }); 214 }, 215 216 collapseOperationsForResource: function(resource) { 217 // Make sure the resource container is open.. 218 Docs.expandEndpointListForResource(resource); 219 220 if (resource == '') { 221 $('.resource ul.endpoints li.operation div.content').slideUp(); 222 return; 223 } 224 225 $('li#resource_' + Docs.escapeResourceName(resource) + ' li.operation div.content').each(function() { 226 Docs.collapseOperation($(this)); 227 }); 228 }, 229 230 escapeResourceName: function(resource) { 231 return resource.replace(/[!"#$%&'()*+,.\/:;<=>?@\[\\\]\^`{|}~]/g, "\\$&"); 232 }, 233 234 expandOperation: function(elem) { 235 elem.slideDown(); 236 }, 237 238 collapseOperation: function(elem) { 239 elem.slideUp(); 240 } 241 }; 242 243 'use strict'; 244 245 Handlebars.registerHelper('sanitize', function(html) { 246 // Strip the script tags from the html, and return it as a Handlebars.SafeString 247 html = html.replace(/<script\b[^<]*(?:(?!<\/script>)<[^<]*)*<\/script>/gi, ''); 248 return new Handlebars.SafeString(html); 249 }); 250 251 Handlebars.registerHelper('renderTextParam', function(param) { 252 var result, type = 'text', idAtt = ''; 253 var paramType = param.type || param.schema.type || ''; 254 var isArray = paramType.toLowerCase() === 'array' || param.allowMultiple; 255 var defaultValue = isArray && Array.isArray(param.default) ? param.default.join('\n') : param.default; 256 257 var dataVendorExtensions = Object.keys(param).filter(function(property) { 258 // filter X-data- properties 259 return property.match(/^X-data-/i) !== null; 260 }).reduce(function(result, property) { 261 // remove X- from property name, so it results in html attributes like data-foo='bar' 262 return result += ' ' + property.substring(2, property.length) + '=\'' + param[property] + '\''; 263 }, ''); 264 265 if (typeof defaultValue === 'undefined') { 266 defaultValue = ''; 267 } 268 269 if(param.format && param.format === 'password') { 270 type = 'password'; 271 } 272 273 if(param.valueId) { 274 idAtt = ' id=\'' + param.valueId + '\''; 275 } 276 277 if (typeof defaultValue === 'string' || defaultValue instanceof String) { 278 defaultValue = defaultValue.replace(/'/g,'''); 279 } 280 281 if(isArray) { 282 result = '<textarea class=\'body-textarea' + (param.required ? ' required' : '') + '\' name=\'' + param.name + '\'' + idAtt + dataVendorExtensions; 283 result += ' placeholder=\'Provide multiple values in new lines' + (param.required ? ' (at least one required).' : '.') + '\'>'; 284 result += defaultValue + '</textarea>'; 285 } else { 286 var parameterClass = 'parameter'; 287 if(param.required) { 288 parameterClass += ' required'; 289 } 290 result = '<input class=\'' + parameterClass + '\' minlength=\'' + (param.required ? 1 : 0) + '\''; 291 result += ' name=\'' + param.name +'\' placeholder=\'' + (param.required ? '(required)' : '') + '\'' + idAtt + dataVendorExtensions; 292 result += ' type=\'' + type + '\' value=\'' + defaultValue + '\'/>'; 293 } 294 return new Handlebars.SafeString(result); 295 }); 296 297 this["Handlebars"]["templates"]["main"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 298 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression, buffer = " <div class=\"info_title\">" 299 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.title : stack1), depth0)) 300 + "</div>\n <div class=\"info_description markdown\">"; 301 stack1 = lambda(((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.description : stack1), depth0); 302 if (stack1 != null) { buffer += stack1; } 303 buffer += "</div>\n"; 304 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.externalDocs : depth0), {"name":"if","hash":{},"fn":this.program(2, data),"inverse":this.noop,"data":data}); 305 if (stack1 != null) { buffer += stack1; } 306 buffer += " "; 307 stack1 = helpers['if'].call(depth0, ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.termsOfServiceUrl : stack1), {"name":"if","hash":{},"fn":this.program(4, data),"inverse":this.noop,"data":data}); 308 if (stack1 != null) { buffer += stack1; } 309 buffer += "\n "; 310 stack1 = helpers['if'].call(depth0, ((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.name : stack1), {"name":"if","hash":{},"fn":this.program(6, data),"inverse":this.noop,"data":data}); 311 if (stack1 != null) { buffer += stack1; } 312 buffer += "\n "; 313 stack1 = helpers['if'].call(depth0, ((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.url : stack1), {"name":"if","hash":{},"fn":this.program(8, data),"inverse":this.noop,"data":data}); 314 if (stack1 != null) { buffer += stack1; } 315 buffer += "\n "; 316 stack1 = helpers['if'].call(depth0, ((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.email : stack1), {"name":"if","hash":{},"fn":this.program(10, data),"inverse":this.noop,"data":data}); 317 if (stack1 != null) { buffer += stack1; } 318 buffer += "\n "; 319 stack1 = helpers['if'].call(depth0, ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.license : stack1), {"name":"if","hash":{},"fn":this.program(12, data),"inverse":this.noop,"data":data}); 320 if (stack1 != null) { buffer += stack1; } 321 return buffer + "\n"; 322 },"2":function(depth0,helpers,partials,data) { 323 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 324 return " <p>" 325 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.externalDocs : depth0)) != null ? stack1.description : stack1), depth0)) 326 + "</p>\n <a href=\"" 327 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.externalDocs : depth0)) != null ? stack1.url : stack1), depth0)) 328 + "\" target=\"_blank\">" 329 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.externalDocs : depth0)) != null ? stack1.url : stack1), depth0)) 330 + "</a>\n"; 331 },"4":function(depth0,helpers,partials,data) { 332 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 333 return "<div class=\"info_tos\"><a href=\"" 334 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.termsOfServiceUrl : stack1), depth0)) 335 + "\" data-sw-translate>Terms of service</a></div>"; 336 },"6":function(depth0,helpers,partials,data) { 337 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 338 return "<div class='info_name' data-sw-translate>Created by " 339 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.name : stack1), depth0)) 340 + "</div>"; 341 },"8":function(depth0,helpers,partials,data) { 342 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 343 return "<div class='info_url' data-sw-translate>See more at <a href=\"" 344 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.url : stack1), depth0)) 345 + "\">" 346 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.url : stack1), depth0)) 347 + "</a></div>"; 348 },"10":function(depth0,helpers,partials,data) { 349 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 350 return "<div class='info_email'><a href=\"mailto:" 351 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.contact : stack1)) != null ? stack1.email : stack1), depth0)) 352 + "?subject=" 353 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.title : stack1), depth0)) 354 + "\" data-sw-translate>Contact the developer</a></div>"; 355 },"12":function(depth0,helpers,partials,data) { 356 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 357 return "<div class='info_license'><a href='" 358 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.license : stack1)) != null ? stack1.url : stack1), depth0)) 359 + "'>" 360 + escapeExpression(lambda(((stack1 = ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.license : stack1)) != null ? stack1.name : stack1), depth0)) 361 + "</a></div>"; 362 },"14":function(depth0,helpers,partials,data) { 363 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression; 364 return " , <span style=\"font-variant: small-caps\" data-sw-translate>api version</span>: " 365 + escapeExpression(lambda(((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.version : stack1), depth0)) 366 + "\n "; 367 },"16":function(depth0,helpers,partials,data) { 368 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 369 return " <span style=\"float:right\"><a href=\"" 370 + escapeExpression(((helper = (helper = helpers.validatorUrl || (depth0 != null ? depth0.validatorUrl : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"validatorUrl","hash":{},"data":data}) : helper))) 371 + "/debug?url=" 372 + escapeExpression(((helper = (helper = helpers.url || (depth0 != null ? depth0.url : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"url","hash":{},"data":data}) : helper))) 373 + "\"><img id=\"validator\" src=\"" 374 + escapeExpression(((helper = (helper = helpers.validatorUrl || (depth0 != null ? depth0.validatorUrl : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"validatorUrl","hash":{},"data":data}) : helper))) 375 + "?url=" 376 + escapeExpression(((helper = (helper = helpers.url || (depth0 != null ? depth0.url : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"url","hash":{},"data":data}) : helper))) 377 + "\"></a>\n </span>\n"; 378 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 379 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<div class='info' id='api_info'>\n"; 380 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.info : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.noop,"data":data}); 381 if (stack1 != null) { buffer += stack1; } 382 buffer += "</div>\n<div class='container' id='resources_container'>\n <ul id='resources'></ul>\n\n <div class=\"footer\">\n <h4 style=\"color: #999\">[ <span style=\"font-variant: small-caps\">base url</span>: " 383 + escapeExpression(((helper = (helper = helpers.basePath || (depth0 != null ? depth0.basePath : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"basePath","hash":{},"data":data}) : helper))) 384 + "\n"; 385 stack1 = helpers['if'].call(depth0, ((stack1 = (depth0 != null ? depth0.info : depth0)) != null ? stack1.version : stack1), {"name":"if","hash":{},"fn":this.program(14, data),"inverse":this.noop,"data":data}); 386 if (stack1 != null) { buffer += stack1; } 387 buffer += "]\n"; 388 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.validatorUrl : depth0), {"name":"if","hash":{},"fn":this.program(16, data),"inverse":this.noop,"data":data}); 389 if (stack1 != null) { buffer += stack1; } 390 return buffer + " </h4>\n </div>\n</div>\n"; 391 },"useData":true}); 392 this["Handlebars"]["templates"]["operation"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 393 return "deprecated"; 394 },"3":function(depth0,helpers,partials,data) { 395 return " <h4><span data-sw-translate>Warning: Deprecated</span></h4>\n"; 396 },"5":function(depth0,helpers,partials,data) { 397 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, buffer = " <h4><span data-sw-translate>Implementation Notes</span></h4>\n <div class=\"markdown\">"; 398 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 399 if (stack1 != null) { buffer += stack1; } 400 return buffer + "</div>\n"; 401 },"7":function(depth0,helpers,partials,data) { 402 return " <div class=\"auth\">\n <span class=\"api-ic ic-error\">"; 403 },"9":function(depth0,helpers,partials,data) { 404 var stack1, buffer = " <div class=\"api_information_panel\">\n"; 405 stack1 = helpers.each.call(depth0, depth0, {"name":"each","hash":{},"fn":this.program(10, data),"inverse":this.noop,"data":data}); 406 if (stack1 != null) { buffer += stack1; } 407 return buffer + " </div>\n"; 408 },"10":function(depth0,helpers,partials,data) { 409 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression, buffer = " <div title='"; 410 stack1 = lambda((depth0 != null ? depth0.description : depth0), depth0); 411 if (stack1 != null) { buffer += stack1; } 412 return buffer + "'>" 413 + escapeExpression(lambda((depth0 != null ? depth0.scope : depth0), depth0)) 414 + "</div>\n"; 415 },"12":function(depth0,helpers,partials,data) { 416 return "</span></div>"; 417 },"14":function(depth0,helpers,partials,data) { 418 return " <div class='access'>\n <span class=\"api-ic ic-off\" title=\"click to authenticate\"></span>\n </div>\n"; 419 },"16":function(depth0,helpers,partials,data) { 420 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = " <h4><span data-sw-translate>Response Class</span> (<span data-sw-translate>Status</span> " 421 + escapeExpression(((helper = (helper = helpers.successCode || (depth0 != null ? depth0.successCode : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"successCode","hash":{},"data":data}) : helper))) 422 + ")</h4>\n "; 423 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.successDescription : depth0), {"name":"if","hash":{},"fn":this.program(17, data),"inverse":this.noop,"data":data}); 424 if (stack1 != null) { buffer += stack1; } 425 return buffer + "\n <p><span class=\"model-signature\" /></p>\n <br/>\n <div class=\"response-content-type\" />\n\n"; 426 },"17":function(depth0,helpers,partials,data) { 427 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, buffer = "<div class=\"markdown\">"; 428 stack1 = ((helper = (helper = helpers.successDescription || (depth0 != null ? depth0.successDescription : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"successDescription","hash":{},"data":data}) : helper)); 429 if (stack1 != null) { buffer += stack1; } 430 return buffer + "</div>"; 431 },"19":function(depth0,helpers,partials,data) { 432 var stack1, buffer = " <h4 data-sw-translate>Headers</h4>\n <table class=\"headers\">\n <thead>\n <tr>\n <th style=\"width: 100px; max-width: 100px\" data-sw-translate>Header</th>\n <th style=\"width: 310px; max-width: 310px\" data-sw-translate>Description</th>\n <th style=\"width: 200px; max-width: 200px\" data-sw-translate>Type</th>\n <th style=\"width: 320px; max-width: 320px\" data-sw-translate>Other</th>\n </tr>\n </thead>\n <tbody>\n"; 433 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.headers : depth0), {"name":"each","hash":{},"fn":this.program(20, data),"inverse":this.noop,"data":data}); 434 if (stack1 != null) { buffer += stack1; } 435 return buffer + " </tbody>\n </table>\n"; 436 },"20":function(depth0,helpers,partials,data) { 437 var lambda=this.lambda, escapeExpression=this.escapeExpression; 438 return " <tr>\n <td>" 439 + escapeExpression(lambda((data && data.key), depth0)) 440 + "</td>\n <td>" 441 + escapeExpression(lambda((depth0 != null ? depth0.description : depth0), depth0)) 442 + "</td>\n <td>" 443 + escapeExpression(lambda((depth0 != null ? depth0.type : depth0), depth0)) 444 + "</td>\n <td>" 445 + escapeExpression(lambda((depth0 != null ? depth0.other : depth0), depth0)) 446 + "</td>\n </tr>\n"; 447 },"22":function(depth0,helpers,partials,data) { 448 return " <h4 data-sw-translate>Parameters</h4>\n <table class='fullwidth'>\n <thead>\n <tr>\n <th style=\"width: 100px; max-width: 100px\" data-sw-translate>Parameter</th>\n <th style=\"width: 310px; max-width: 310px\" data-sw-translate>Value</th>\n <th style=\"width: 200px; max-width: 200px\" data-sw-translate>Description</th>\n <th style=\"width: 100px; max-width: 100px\" data-sw-translate>Parameter Type</th>\n <th style=\"width: 220px; max-width: 230px\" data-sw-translate>Data Type</th>\n </tr>\n </thead>\n <tbody class=\"operation-params\">\n\n </tbody>\n </table>\n"; 449 },"24":function(depth0,helpers,partials,data) { 450 return " <div style='margin:0;padding:0;display:inline'></div>\n <h4 data-sw-translate>Response Messages</h4>\n <table class='fullwidth'>\n <thead>\n <tr>\n <th data-sw-translate>HTTP Status Code</th>\n <th data-sw-translate>Reason</th>\n <th data-sw-translate>Response Model</th>\n <th data-sw-translate>Headers</th>\n </tr>\n </thead>\n <tbody class=\"operation-status\">\n </tbody>\n </table>\n"; 451 },"26":function(depth0,helpers,partials,data) { 452 return ""; 453 },"28":function(depth0,helpers,partials,data) { 454 return " <div class='sandbox_header'>\n <input class='submit' type='submit' value='Try it out!' data-sw-translate/>\n <a href='#' class='response_hider' style='display:none' data-sw-translate>Hide Response</a>\n <span class='response_throbber' style='display:none'></span>\n </div>\n"; 455 },"30":function(depth0,helpers,partials,data) { 456 return " <h4 data-sw-translate>Request Headers</h4>\n <div class='block request_headers'></div>\n"; 457 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 458 var stack1, helper, options, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, blockHelperMissing=helpers.blockHelperMissing, buffer = "\n <ul class='operations' >\n <li class='" 459 + escapeExpression(((helper = (helper = helpers.method || (depth0 != null ? depth0.method : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"method","hash":{},"data":data}) : helper))) 460 + " operation' id='" 461 + escapeExpression(((helper = (helper = helpers.parentId || (depth0 != null ? depth0.parentId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"parentId","hash":{},"data":data}) : helper))) 462 + "_" 463 + escapeExpression(((helper = (helper = helpers.nickname || (depth0 != null ? depth0.nickname : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"nickname","hash":{},"data":data}) : helper))) 464 + "'>\n <div class='heading'>\n <h3>\n <span class='http_method'>\n <a href='#!/" 465 + escapeExpression(((helper = (helper = helpers.encodedParentId || (depth0 != null ? depth0.encodedParentId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"encodedParentId","hash":{},"data":data}) : helper))) 466 + "/" 467 + escapeExpression(((helper = (helper = helpers.nickname || (depth0 != null ? depth0.nickname : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"nickname","hash":{},"data":data}) : helper))) 468 + "' class=\"toggleOperation\">" 469 + escapeExpression(((helper = (helper = helpers.method || (depth0 != null ? depth0.method : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"method","hash":{},"data":data}) : helper))) 470 + "</a>\n </span>\n <span class='path'>\n <a href='#!/" 471 + escapeExpression(((helper = (helper = helpers.encodedParentId || (depth0 != null ? depth0.encodedParentId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"encodedParentId","hash":{},"data":data}) : helper))) 472 + "/" 473 + escapeExpression(((helper = (helper = helpers.nickname || (depth0 != null ? depth0.nickname : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"nickname","hash":{},"data":data}) : helper))) 474 + "' class=\"toggleOperation "; 475 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.deprecated : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.noop,"data":data}); 476 if (stack1 != null) { buffer += stack1; } 477 buffer += "\">" 478 + escapeExpression(((helper = (helper = helpers.path || (depth0 != null ? depth0.path : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"path","hash":{},"data":data}) : helper))) 479 + "</a>\n </span>\n </h3>\n <ul class='options'>\n <li>\n <a href='#!/" 480 + escapeExpression(((helper = (helper = helpers.encodedParentId || (depth0 != null ? depth0.encodedParentId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"encodedParentId","hash":{},"data":data}) : helper))) 481 + "/" 482 + escapeExpression(((helper = (helper = helpers.nickname || (depth0 != null ? depth0.nickname : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"nickname","hash":{},"data":data}) : helper))) 483 + "' class=\"toggleOperation\">"; 484 stack1 = ((helper = (helper = helpers.summary || (depth0 != null ? depth0.summary : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"summary","hash":{},"data":data}) : helper)); 485 if (stack1 != null) { buffer += stack1; } 486 buffer += "</a>\n </li>\n </ul>\n </div>\n <div class='content' id='" 487 + escapeExpression(((helper = (helper = helpers.parentId || (depth0 != null ? depth0.parentId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"parentId","hash":{},"data":data}) : helper))) 488 + "_" 489 + escapeExpression(((helper = (helper = helpers.nickname || (depth0 != null ? depth0.nickname : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"nickname","hash":{},"data":data}) : helper))) 490 + "_content' style='display:none'>\n"; 491 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.deprecated : depth0), {"name":"if","hash":{},"fn":this.program(3, data),"inverse":this.noop,"data":data}); 492 if (stack1 != null) { buffer += stack1; } 493 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.description : depth0), {"name":"if","hash":{},"fn":this.program(5, data),"inverse":this.noop,"data":data}); 494 if (stack1 != null) { buffer += stack1; } 495 stack1 = ((helper = (helper = helpers.oauth || (depth0 != null ? depth0.oauth : depth0)) != null ? helper : helperMissing),(options={"name":"oauth","hash":{},"fn":this.program(7, data),"inverse":this.noop,"data":data}),(typeof helper === functionType ? helper.call(depth0, options) : helper)); 496 if (!helpers.oauth) { stack1 = blockHelperMissing.call(depth0, stack1, options); } 497 if (stack1 != null) { buffer += stack1; } 498 buffer += "\n"; 499 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.oauth : depth0), {"name":"each","hash":{},"fn":this.program(9, data),"inverse":this.noop,"data":data}); 500 if (stack1 != null) { buffer += stack1; } 501 buffer += " "; 502 stack1 = ((helper = (helper = helpers.oauth || (depth0 != null ? depth0.oauth : depth0)) != null ? helper : helperMissing),(options={"name":"oauth","hash":{},"fn":this.program(12, data),"inverse":this.noop,"data":data}),(typeof helper === functionType ? helper.call(depth0, options) : helper)); 503 if (!helpers.oauth) { stack1 = blockHelperMissing.call(depth0, stack1, options); } 504 if (stack1 != null) { buffer += stack1; } 505 buffer += "\n"; 506 stack1 = ((helper = (helper = helpers.oauth || (depth0 != null ? depth0.oauth : depth0)) != null ? helper : helperMissing),(options={"name":"oauth","hash":{},"fn":this.program(14, data),"inverse":this.noop,"data":data}),(typeof helper === functionType ? helper.call(depth0, options) : helper)); 507 if (!helpers.oauth) { stack1 = blockHelperMissing.call(depth0, stack1, options); } 508 if (stack1 != null) { buffer += stack1; } 509 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.type : depth0), {"name":"if","hash":{},"fn":this.program(16, data),"inverse":this.noop,"data":data}); 510 if (stack1 != null) { buffer += stack1; } 511 buffer += "\n"; 512 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.headers : depth0), {"name":"if","hash":{},"fn":this.program(19, data),"inverse":this.noop,"data":data}); 513 if (stack1 != null) { buffer += stack1; } 514 buffer += "\n <form accept-charset='UTF-8' class='sandbox'>\n <div style='margin:0;padding:0;display:inline'></div>\n"; 515 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.parameters : depth0), {"name":"if","hash":{},"fn":this.program(22, data),"inverse":this.noop,"data":data}); 516 if (stack1 != null) { buffer += stack1; } 517 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.responseMessages : depth0), {"name":"if","hash":{},"fn":this.program(24, data),"inverse":this.noop,"data":data}); 518 if (stack1 != null) { buffer += stack1; } 519 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isReadOnly : depth0), {"name":"if","hash":{},"fn":this.program(26, data),"inverse":this.program(28, data),"data":data}); 520 if (stack1 != null) { buffer += stack1; } 521 buffer += " </form>\n <div class='response' style='display:none'>\n <h4 class='curl'>Curl</h4>\n <div class='block curl'></div>\n <h4 data-sw-translate>Request URL</h4>\n <div class='block request_url'></div>\n"; 522 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.showRequestHeaders : depth0), {"name":"if","hash":{},"fn":this.program(30, data),"inverse":this.noop,"data":data}); 523 if (stack1 != null) { buffer += stack1; } 524 return buffer + " <h4 data-sw-translate>Response Body</h4>\n <div class='block response_body'></div>\n <h4 data-sw-translate>Response Code</h4>\n <div class='block response_code'></div>\n <h4 data-sw-translate>Response Headers</h4>\n <div class='block response_headers'></div>\n </div>\n </div>\n </li>\n </ul>\n"; 525 },"useData":true}); 526 this["Handlebars"]["templates"]["param_list"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 527 return " required"; 528 },"3":function(depth0,helpers,partials,data) { 529 return " multiple=\"multiple\""; 530 },"5":function(depth0,helpers,partials,data) { 531 return " required "; 532 },"7":function(depth0,helpers,partials,data) { 533 var stack1, buffer = " <option "; 534 stack1 = helpers.unless.call(depth0, (depth0 != null ? depth0.hasDefault : depth0), {"name":"unless","hash":{},"fn":this.program(8, data),"inverse":this.noop,"data":data}); 535 if (stack1 != null) { buffer += stack1; } 536 return buffer + " value=''></option>\n"; 537 },"8":function(depth0,helpers,partials,data) { 538 return " selected=\"\" "; 539 },"10":function(depth0,helpers,partials,data) { 540 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "\n <option "; 541 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isDefault : depth0), {"name":"if","hash":{},"fn":this.program(11, data),"inverse":this.noop,"data":data}); 542 if (stack1 != null) { buffer += stack1; } 543 buffer += " value='" 544 + escapeExpression(((helper = (helper = helpers.value || (depth0 != null ? depth0.value : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"value","hash":{},"data":data}) : helper))) 545 + "'> " 546 + escapeExpression(((helper = (helper = helpers.value || (depth0 != null ? depth0.value : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"value","hash":{},"data":data}) : helper))) 547 + " "; 548 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isDefault : depth0), {"name":"if","hash":{},"fn":this.program(13, data),"inverse":this.noop,"data":data}); 549 if (stack1 != null) { buffer += stack1; } 550 return buffer + " </option>\n\n"; 551 },"11":function(depth0,helpers,partials,data) { 552 return " selected=\"\" "; 553 },"13":function(depth0,helpers,partials,data) { 554 return " (default) "; 555 },"15":function(depth0,helpers,partials,data) { 556 return "<strong>"; 557 },"17":function(depth0,helpers,partials,data) { 558 return "</strong>"; 559 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 560 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td class='code"; 561 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.required : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.noop,"data":data}); 562 if (stack1 != null) { buffer += stack1; } 563 buffer += "'><label for='" 564 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 565 + "'>" 566 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 567 + "</label></td>\n<td>\n <select "; 568 stack1 = ((helpers.isArray || (depth0 && depth0.isArray) || helperMissing).call(depth0, depth0, {"name":"isArray","hash":{},"fn":this.program(3, data),"inverse":this.noop,"data":data})); 569 if (stack1 != null) { buffer += stack1; } 570 buffer += " class=\"parameter "; 571 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.required : depth0), {"name":"if","hash":{},"fn":this.program(5, data),"inverse":this.noop,"data":data}); 572 if (stack1 != null) { buffer += stack1; } 573 buffer += "\" name=\"" 574 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 575 + "\" id=\"" 576 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 577 + "\">\n\n"; 578 stack1 = helpers.unless.call(depth0, (depth0 != null ? depth0.required : depth0), {"name":"unless","hash":{},"fn":this.program(7, data),"inverse":this.noop,"data":data}); 579 if (stack1 != null) { buffer += stack1; } 580 buffer += "\n"; 581 stack1 = helpers.each.call(depth0, ((stack1 = (depth0 != null ? depth0.allowableValues : depth0)) != null ? stack1.descriptiveValues : stack1), {"name":"each","hash":{},"fn":this.program(10, data),"inverse":this.noop,"data":data}); 582 if (stack1 != null) { buffer += stack1; } 583 buffer += "\n </select>\n</td>\n<td class=\"markdown\">"; 584 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.required : depth0), {"name":"if","hash":{},"fn":this.program(15, data),"inverse":this.noop,"data":data}); 585 if (stack1 != null) { buffer += stack1; } 586 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 587 if (stack1 != null) { buffer += stack1; } 588 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.required : depth0), {"name":"if","hash":{},"fn":this.program(17, data),"inverse":this.noop,"data":data}); 589 if (stack1 != null) { buffer += stack1; } 590 buffer += "</td>\n<td>"; 591 stack1 = ((helper = (helper = helpers.paramType || (depth0 != null ? depth0.paramType : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"paramType","hash":{},"data":data}) : helper)); 592 if (stack1 != null) { buffer += stack1; } 593 return buffer + "</td>\n<td><span class=\"model-signature\"></span></td>\n"; 594 },"useData":true}); 595 this["Handlebars"]["templates"]["param_readonly_required"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 596 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 597 return " <textarea class='body-textarea' readonly='readonly' placeholder='(required)' name='" 598 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 599 + "' id='" 600 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 601 + "'>" 602 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 603 + "</textarea>\n"; 604 },"3":function(depth0,helpers,partials,data) { 605 var stack1, buffer = ""; 606 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0['default'] : depth0), {"name":"if","hash":{},"fn":this.program(4, data),"inverse":this.program(6, data),"data":data}); 607 if (stack1 != null) { buffer += stack1; } 608 return buffer; 609 },"4":function(depth0,helpers,partials,data) { 610 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 611 return " " 612 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 613 + "\n"; 614 },"6":function(depth0,helpers,partials,data) { 615 return " (empty)\n"; 616 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 617 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td class='code required'><label for='" 618 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 619 + "'>" 620 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 621 + "</label></td>\n<td>\n"; 622 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isBody : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(3, data),"data":data}); 623 if (stack1 != null) { buffer += stack1; } 624 buffer += "</td>\n<td class=\"markdown\">"; 625 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 626 if (stack1 != null) { buffer += stack1; } 627 buffer += "</td>\n<td>"; 628 stack1 = ((helper = (helper = helpers.paramType || (depth0 != null ? depth0.paramType : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"paramType","hash":{},"data":data}) : helper)); 629 if (stack1 != null) { buffer += stack1; } 630 return buffer + "</td>\n<td><span class=\"model-signature\"></span></td>\n"; 631 },"useData":true}); 632 this["Handlebars"]["templates"]["param_readonly"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 633 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 634 return " <textarea class='body-textarea' readonly='readonly' name='" 635 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 636 + "' id='" 637 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 638 + "'>" 639 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 640 + "</textarea>\n <div class=\"parameter-content-type\" />\n"; 641 },"3":function(depth0,helpers,partials,data) { 642 var stack1, buffer = ""; 643 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0['default'] : depth0), {"name":"if","hash":{},"fn":this.program(4, data),"inverse":this.program(6, data),"data":data}); 644 if (stack1 != null) { buffer += stack1; } 645 return buffer; 646 },"4":function(depth0,helpers,partials,data) { 647 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 648 return " " 649 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 650 + "\n"; 651 },"6":function(depth0,helpers,partials,data) { 652 return " (empty)\n"; 653 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 654 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td class='code'><label for='" 655 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 656 + "'>" 657 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 658 + "</label></td>\n<td>\n"; 659 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isBody : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(3, data),"data":data}); 660 if (stack1 != null) { buffer += stack1; } 661 buffer += "</td>\n<td class=\"markdown\">"; 662 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 663 if (stack1 != null) { buffer += stack1; } 664 buffer += "</td>\n<td>"; 665 stack1 = ((helper = (helper = helpers.paramType || (depth0 != null ? depth0.paramType : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"paramType","hash":{},"data":data}) : helper)); 666 if (stack1 != null) { buffer += stack1; } 667 return buffer + "</td>\n<td><span class=\"model-signature\"></span></td>\n"; 668 },"useData":true}); 669 this["Handlebars"]["templates"]["param_required"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 670 var stack1, buffer = ""; 671 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isFile : depth0), {"name":"if","hash":{},"fn":this.program(2, data),"inverse":this.program(4, data),"data":data}); 672 if (stack1 != null) { buffer += stack1; } 673 return buffer; 674 },"2":function(depth0,helpers,partials,data) { 675 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 676 return " <input type=\"file\" name='" 677 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 678 + "' id='" 679 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 680 + "'/>\n"; 681 },"4":function(depth0,helpers,partials,data) { 682 var stack1, buffer = ""; 683 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0['default'] : depth0), {"name":"if","hash":{},"fn":this.program(5, data),"inverse":this.program(7, data),"data":data}); 684 if (stack1 != null) { buffer += stack1; } 685 return buffer; 686 },"5":function(depth0,helpers,partials,data) { 687 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 688 return " <div class=\"editor_holder\"></div>\n <textarea class='body-textarea required' placeholder='(required)' name='" 689 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 690 + "' id=\"" 691 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 692 + "\">" 693 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 694 + "</textarea>\n <br />\n <div class=\"parameter-content-type\" />\n"; 695 },"7":function(depth0,helpers,partials,data) { 696 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 697 return " <textarea class='body-textarea required' placeholder='(required)' name='" 698 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 699 + "' id='" 700 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 701 + "'></textarea>\n <div class=\"editor_holder\"></div>\n <br />\n <div class=\"parameter-content-type\" />\n"; 702 },"9":function(depth0,helpers,partials,data) { 703 var stack1, buffer = ""; 704 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isFile : depth0), {"name":"if","hash":{},"fn":this.program(10, data),"inverse":this.program(12, data),"data":data}); 705 if (stack1 != null) { buffer += stack1; } 706 return buffer; 707 },"10":function(depth0,helpers,partials,data) { 708 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 709 return " <input class='parameter' class='required' type='file' name='" 710 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 711 + "' id='" 712 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 713 + "'/>\n"; 714 },"12":function(depth0,helpers,partials,data) { 715 var stack1, helperMissing=helpers.helperMissing, buffer = ""; 716 stack1 = ((helpers.renderTextParam || (depth0 && depth0.renderTextParam) || helperMissing).call(depth0, depth0, {"name":"renderTextParam","hash":{},"fn":this.program(13, data),"inverse":this.noop,"data":data})); 717 if (stack1 != null) { buffer += stack1; } 718 return buffer; 719 },"13":function(depth0,helpers,partials,data) { 720 return ""; 721 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 722 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td class='code required'><label for='" 723 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 724 + "'>" 725 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 726 + "</label></td>\n<td>\n"; 727 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isBody : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(9, data),"data":data}); 728 if (stack1 != null) { buffer += stack1; } 729 buffer += "</td>\n<td>\n <strong><span class=\"markdown\">"; 730 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 731 if (stack1 != null) { buffer += stack1; } 732 buffer += "</span></strong>\n</td>\n<td>"; 733 stack1 = ((helper = (helper = helpers.paramType || (depth0 != null ? depth0.paramType : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"paramType","hash":{},"data":data}) : helper)); 734 if (stack1 != null) { buffer += stack1; } 735 return buffer + "</td>\n<td><span class=\"model-signature\"></span></td>\n"; 736 },"useData":true}); 737 this["Handlebars"]["templates"]["param"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 738 var stack1, buffer = ""; 739 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isFile : depth0), {"name":"if","hash":{},"fn":this.program(2, data),"inverse":this.program(4, data),"data":data}); 740 if (stack1 != null) { buffer += stack1; } 741 return buffer; 742 },"2":function(depth0,helpers,partials,data) { 743 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 744 return " <input type=\"file\" name='" 745 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 746 + "' id='" 747 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 748 + "'/>\n <div class=\"parameter-content-type\" />\n"; 749 },"4":function(depth0,helpers,partials,data) { 750 var stack1, buffer = ""; 751 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0['default'] : depth0), {"name":"if","hash":{},"fn":this.program(5, data),"inverse":this.program(7, data),"data":data}); 752 if (stack1 != null) { buffer += stack1; } 753 return buffer; 754 },"5":function(depth0,helpers,partials,data) { 755 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 756 return " <div class=\"editor_holder\"></div>\n <textarea class='body-textarea' name='" 757 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 758 + "' id='" 759 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 760 + "'>" 761 + escapeExpression(((helper = (helper = helpers['default'] || (depth0 != null ? depth0['default'] : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"default","hash":{},"data":data}) : helper))) 762 + "</textarea>\n <br />\n <div class=\"parameter-content-type\" />\n"; 763 },"7":function(depth0,helpers,partials,data) { 764 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 765 return " <textarea class='body-textarea' name='" 766 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 767 + "' id='" 768 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 769 + "'></textarea>\n <div class=\"editor_holder\"></div>\n <br />\n <div class=\"parameter-content-type\" />\n"; 770 },"9":function(depth0,helpers,partials,data) { 771 var stack1, buffer = ""; 772 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isFile : depth0), {"name":"if","hash":{},"fn":this.program(2, data),"inverse":this.program(10, data),"data":data}); 773 if (stack1 != null) { buffer += stack1; } 774 return buffer; 775 },"10":function(depth0,helpers,partials,data) { 776 var stack1, helperMissing=helpers.helperMissing, buffer = ""; 777 stack1 = ((helpers.renderTextParam || (depth0 && depth0.renderTextParam) || helperMissing).call(depth0, depth0, {"name":"renderTextParam","hash":{},"fn":this.program(11, data),"inverse":this.noop,"data":data})); 778 if (stack1 != null) { buffer += stack1; } 779 return buffer; 780 },"11":function(depth0,helpers,partials,data) { 781 return ""; 782 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 783 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td class='code'><label for='" 784 + escapeExpression(((helper = (helper = helpers.valueId || (depth0 != null ? depth0.valueId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"valueId","hash":{},"data":data}) : helper))) 785 + "'>" 786 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 787 + "</label></td>\n<td>\n\n"; 788 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.isBody : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(9, data),"data":data}); 789 if (stack1 != null) { buffer += stack1; } 790 buffer += "\n</td>\n<td class=\"markdown\">"; 791 stack1 = ((helper = (helper = helpers.description || (depth0 != null ? depth0.description : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"description","hash":{},"data":data}) : helper)); 792 if (stack1 != null) { buffer += stack1; } 793 buffer += "</td>\n<td>"; 794 stack1 = ((helper = (helper = helpers.paramType || (depth0 != null ? depth0.paramType : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"paramType","hash":{},"data":data}) : helper)); 795 if (stack1 != null) { buffer += stack1; } 796 return buffer + "</td>\n<td>\n <span class=\"model-signature\"></span>\n</td>\n"; 797 },"useData":true}); 798 this["Handlebars"]["templates"]["parameter_content_type"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 799 var stack1, buffer = ""; 800 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.consumes : depth0), {"name":"each","hash":{},"fn":this.program(2, data),"inverse":this.noop,"data":data}); 801 if (stack1 != null) { buffer += stack1; } 802 return buffer; 803 },"2":function(depth0,helpers,partials,data) { 804 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression, buffer = " <option value=\"" 805 + escapeExpression(lambda(depth0, depth0)) 806 + "\">"; 807 stack1 = lambda(depth0, depth0); 808 if (stack1 != null) { buffer += stack1; } 809 return buffer + "</option>\n"; 810 },"4":function(depth0,helpers,partials,data) { 811 return " <option value=\"application/json\">application/json</option>\n"; 812 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 813 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<label for=\"" 814 + escapeExpression(((helper = (helper = helpers.parameterContentTypeId || (depth0 != null ? depth0.parameterContentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"parameterContentTypeId","hash":{},"data":data}) : helper))) 815 + "\" data-sw-translate>Parameter content type:</label>\n<select name=\"parameterContentType\" id=\"" 816 + escapeExpression(((helper = (helper = helpers.parameterContentTypeId || (depth0 != null ? depth0.parameterContentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"parameterContentTypeId","hash":{},"data":data}) : helper))) 817 + "\">\n"; 818 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.consumes : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(4, data),"data":data}); 819 if (stack1 != null) { buffer += stack1; } 820 return buffer + "</select>\n"; 821 },"useData":true}); 822 this["Handlebars"]["templates"]["resource"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 823 return " : "; 824 },"3":function(depth0,helpers,partials,data) { 825 var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression; 826 return " <li>\n <a href='" 827 + escapeExpression(((helper = (helper = helpers.url || (depth0 != null ? depth0.url : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"url","hash":{},"data":data}) : helper))) 828 + "' data-sw-translate>Raw</a>\n </li>\n"; 829 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 830 var stack1, helper, options, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, blockHelperMissing=helpers.blockHelperMissing, buffer = "<div class='heading'>\n <h2>\n <a href='#!/" 831 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 832 + "' class=\"toggleEndpointList\" data-id=\"" 833 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 834 + "\">" 835 + escapeExpression(((helper = (helper = helpers.name || (depth0 != null ? depth0.name : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"name","hash":{},"data":data}) : helper))) 836 + "</a> "; 837 stack1 = ((helper = (helper = helpers.summary || (depth0 != null ? depth0.summary : depth0)) != null ? helper : helperMissing),(options={"name":"summary","hash":{},"fn":this.program(1, data),"inverse":this.noop,"data":data}),(typeof helper === functionType ? helper.call(depth0, options) : helper)); 838 if (!helpers.summary) { stack1 = blockHelperMissing.call(depth0, stack1, options); } 839 if (stack1 != null) { buffer += stack1; } 840 stack1 = ((helper = (helper = helpers.summary || (depth0 != null ? depth0.summary : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"summary","hash":{},"data":data}) : helper)); 841 if (stack1 != null) { buffer += stack1; } 842 buffer += "\n </h2>\n <ul class='options'>\n <li>\n <a href='#!/" 843 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 844 + "' id='endpointListTogger_" 845 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 846 + "' class=\"toggleEndpointList\" data-id=\"" 847 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 848 + "\" data-sw-translate>Show/Hide</a>\n </li>\n <li>\n <a href='#' class=\"collapseResource\" data-id=\"" 849 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 850 + "\" data-sw-translate>\n List Operations\n </a>\n </li>\n <li>\n <a href='#' class=\"expandResource\" data-id=\"" 851 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 852 + "\" data-sw-translate>\n Expand Operations\n </a>\n </li>\n"; 853 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.url : depth0), {"name":"if","hash":{},"fn":this.program(3, data),"inverse":this.noop,"data":data}); 854 if (stack1 != null) { buffer += stack1; } 855 return buffer + " </ul>\n</div>\n<ul class='endpoints' id='" 856 + escapeExpression(((helper = (helper = helpers.id || (depth0 != null ? depth0.id : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"id","hash":{},"data":data}) : helper))) 857 + "_endpoint_list' style='display:none'>\n\n</ul>\n"; 858 },"useData":true}); 859 this["Handlebars"]["templates"]["response_content_type"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 860 var stack1, buffer = ""; 861 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.produces : depth0), {"name":"each","hash":{},"fn":this.program(2, data),"inverse":this.noop,"data":data}); 862 if (stack1 != null) { buffer += stack1; } 863 return buffer; 864 },"2":function(depth0,helpers,partials,data) { 865 var stack1, lambda=this.lambda, escapeExpression=this.escapeExpression, buffer = " <option value=\"" 866 + escapeExpression(lambda(depth0, depth0)) 867 + "\">"; 868 stack1 = lambda(depth0, depth0); 869 if (stack1 != null) { buffer += stack1; } 870 return buffer + "</option>\n"; 871 },"4":function(depth0,helpers,partials,data) { 872 return " <option value=\"application/json\">application/json</option>\n"; 873 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 874 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<label data-sw-translate for=\"" 875 + escapeExpression(((helper = (helper = helpers.responseContentTypeId || (depth0 != null ? depth0.responseContentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"responseContentTypeId","hash":{},"data":data}) : helper))) 876 + "\">Response Content Type</label>\n<select name=\"responseContentType\" id=\"" 877 + escapeExpression(((helper = (helper = helpers.responseContentTypeId || (depth0 != null ? depth0.responseContentTypeId : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"responseContentTypeId","hash":{},"data":data}) : helper))) 878 + "\">\n"; 879 stack1 = helpers['if'].call(depth0, (depth0 != null ? depth0.produces : depth0), {"name":"if","hash":{},"fn":this.program(1, data),"inverse":this.program(4, data),"data":data}); 880 if (stack1 != null) { buffer += stack1; } 881 return buffer + "</select>\n"; 882 },"useData":true}); 883 this["Handlebars"]["templates"]["signature"] = Handlebars.template({"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 884 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<div>\n<ul class=\"signature-nav\">\n <li><a class=\"description-link\" href=\"#\" data-sw-translate>Model</a></li>\n <li><a class=\"snippet-link\" href=\"#\" data-sw-translate>Model Schema</a></li>\n</ul>\n<div>\n\n<div class=\"signature-container\">\n <div class=\"description\">\n "; 885 stack1 = ((helper = (helper = helpers.signature || (depth0 != null ? depth0.signature : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"signature","hash":{},"data":data}) : helper)); 886 if (stack1 != null) { buffer += stack1; } 887 return buffer + "\n </div>\n\n <div class=\"snippet\">\n <pre><code>" 888 + escapeExpression(((helper = (helper = helpers.sampleJSON || (depth0 != null ? depth0.sampleJSON : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"sampleJSON","hash":{},"data":data}) : helper))) 889 + "</code></pre>\n <small class=\"notice\" data-sw-translate></small>\n </div>\n</div>\n\n"; 890 },"useData":true}); 891 this["Handlebars"]["templates"]["status_code"] = Handlebars.template({"1":function(depth0,helpers,partials,data) { 892 var lambda=this.lambda, escapeExpression=this.escapeExpression; 893 return " <tr>\n <td>" 894 + escapeExpression(lambda((data && data.key), depth0)) 895 + "</td>\n <td>" 896 + escapeExpression(lambda((depth0 != null ? depth0.description : depth0), depth0)) 897 + "</td>\n <td>" 898 + escapeExpression(lambda((depth0 != null ? depth0.type : depth0), depth0)) 899 + "</td>\n </tr>\n"; 900 },"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) { 901 var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = "<td width='15%' class='code'>" 902 + escapeExpression(((helper = (helper = helpers.code || (depth0 != null ? depth0.code : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"code","hash":{},"data":data}) : helper))) 903 + "</td>\n<td class=\"markdown\">"; 904 stack1 = ((helper = (helper = helpers.message || (depth0 != null ? depth0.message : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"message","hash":{},"data":data}) : helper)); 905 if (stack1 != null) { buffer += stack1; } 906 buffer += "</td>\n<td width='50%'><span class=\"model-signature\" /></td>\n<td class=\"headers\">\n <table>\n <tbody>\n"; 907 stack1 = helpers.each.call(depth0, (depth0 != null ? depth0.headers : depth0), {"name":"each","hash":{},"fn":this.program(1, data),"inverse":this.noop,"data":data}); 908 if (stack1 != null) { buffer += stack1; } 909 return buffer + " </tbody>\n </table>\n</td>"; 910 },"useData":true}); 911 /** 912 * swagger-client - swagger-client is a javascript client for use with swaggering APIs. 913 * @version v2.1.10 914 * @link http://swagger.io 915 * @license Apache-2.0 916 */ 917 (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.SwaggerClient = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ 918 'use strict'; 919 920 var auth = require('./lib/auth'); 921 var helpers = require('./lib/helpers'); 922 var SwaggerClient = require('./lib/client'); 923 var deprecationWrapper = function (url, options) { 924 helpers.log('This is deprecated, use "new SwaggerClient" instead.'); 925 926 return new SwaggerClient(url, options); 927 }; 928 929 /* Here for IE8 Support */ 930 if (!Array.prototype.indexOf) { 931 Array.prototype.indexOf = function(obj, start) { 932 for (var i = (start || 0), j = this.length; i < j; i++) { 933 if (this[i] === obj) { return i; } 934 } 935 return -1; 936 }; 937 } 938 939 /* Here for IE8 Support */ 940 if (!String.prototype.trim) { 941 String.prototype.trim = function () { 942 return this.replace(/^\s+|\s+$/g, ''); 943 }; 944 } 945 946 /* Here for node 10.x support */ 947 if (!String.prototype.endsWith) { 948 String.prototype.endsWith = function(suffix) { 949 return this.indexOf(suffix, this.length - suffix.length) !== -1; 950 }; 951 } 952 953 module.exports = SwaggerClient; 954 955 SwaggerClient.ApiKeyAuthorization = auth.ApiKeyAuthorization; 956 SwaggerClient.PasswordAuthorization = auth.PasswordAuthorization; 957 SwaggerClient.CookieAuthorization = auth.CookieAuthorization; 958 SwaggerClient.SwaggerApi = deprecationWrapper; 959 SwaggerClient.SwaggerClient = deprecationWrapper; 960 SwaggerClient.SchemaMarkup = require('./lib/schema-markup'); 961 962 },{"./lib/auth":2,"./lib/client":3,"./lib/helpers":4,"./lib/schema-markup":7}],2:[function(require,module,exports){ 963 'use strict'; 964 965 var helpers = require('./helpers'); 966 var btoa = require('btoa'); // jshint ignore:line 967 var CookieJar = require('cookiejar').CookieJar; 968 var _ = { 969 each: require('lodash-compat/collection/each'), 970 includes: require('lodash-compat/collection/includes'), 971 isObject: require('lodash-compat/lang/isObject'), 972 isArray: require('lodash-compat/lang/isArray') 973 }; 974 975 /** 976 * SwaggerAuthorizations applys the correct authorization to an operation being executed 977 */ 978 var SwaggerAuthorizations = module.exports.SwaggerAuthorizations = function (authz) { 979 this.authz = authz || {}; 980 }; 981 982 /** 983 * Add auths to the hash 984 * Will overwrite any existing 985 * 986 */ 987 SwaggerAuthorizations.prototype.add = function (name, auth) { 988 if(_.isObject(name)) { 989 for (var key in name) { 990 this.authz[key] = name[key]; 991 } 992 } else if(typeof name === 'string' ){ 993 this.authz[name] = auth; 994 } 995 996 return auth; 997 }; 998 999 SwaggerAuthorizations.prototype.remove = function (name) { 1000 return delete this.authz[name]; 1001 }; 1002 1003 SwaggerAuthorizations.prototype.apply = function (obj, securities) { 1004 var status = true; 1005 var applyAll = !securities; 1006 var flattenedSecurities = []; 1007 1008 // Securities could be [ {} ] 1009 _.each(securities, function (obj, key) { 1010 1011 // Make sure we account for securities being [ str ] 1012 if(typeof key === 'string') { 1013 flattenedSecurities.push(key); 1014 } 1015 1016 // Flatten keys in to our array 1017 _.each(obj, function (val, key) { 1018 flattenedSecurities.push(key); 1019 }); 1020 }); 1021 1022 _.each(this.authz, function (auth, authName) { 1023 if(applyAll || _.includes(flattenedSecurities, authName)) { 1024 var newStatus = auth.apply(obj); 1025 status = status && !!newStatus; // logical ORs regarding status 1026 } 1027 }); 1028 1029 return status; 1030 }; 1031 1032 /** 1033 * ApiKeyAuthorization allows a query param or header to be injected 1034 */ 1035 var ApiKeyAuthorization = module.exports.ApiKeyAuthorization = function (name, value, type) { 1036 this.name = name; 1037 this.value = value; 1038 this.type = type; 1039 }; 1040 1041 ApiKeyAuthorization.prototype.apply = function (obj) { 1042 if (this.type === 'query') { 1043 // see if already applied. If so, don't do it again 1044 1045 var qp; 1046 if (obj.url.indexOf('?') > 0) { 1047 qp = obj.url.substring(obj.url.indexOf('?') + 1); 1048 var parts = qp.split('&'); 1049 if(parts && parts.length > 0) { 1050 for(var i = 0; i < parts.length; i++) { 1051 var kv = parts[i].split('='); 1052 if(kv && kv.length > 0) { 1053 if (kv[0] === this.name) { 1054 // skip it 1055 return false; 1056 } 1057 } 1058 } 1059 } 1060 } 1061 1062 if (obj.url.indexOf('?') > 0) { 1063 obj.url = obj.url + '&' + this.name + '=' + this.value; 1064 } else { 1065 obj.url = obj.url + '?' + this.name + '=' + this.value; 1066 } 1067 1068 return true; 1069 } else if (this.type === 'header') { 1070 if(typeof obj.headers[this.name] === 'undefined') { 1071 obj.headers[this.name] = this.value; 1072 } 1073 1074 return true; 1075 } 1076 }; 1077 1078 var CookieAuthorization = module.exports.CookieAuthorization = function (cookie) { 1079 this.cookie = cookie; 1080 }; 1081 1082 CookieAuthorization.prototype.apply = function (obj) { 1083 obj.cookieJar = obj.cookieJar || new CookieJar(); 1084 obj.cookieJar.setCookie(this.cookie); 1085 1086 return true; 1087 }; 1088 1089 /** 1090 * Password Authorization is a basic auth implementation 1091 */ 1092 var PasswordAuthorization = module.exports.PasswordAuthorization = function (username, password) { 1093 if (arguments.length === 3) { 1094 helpers.log('PasswordAuthorization: the \'name\' argument has been removed, pass only username and password'); 1095 username = arguments[1]; 1096 password = arguments[2]; 1097 } 1098 this.username = username; 1099 this.password = password; 1100 }; 1101 1102 PasswordAuthorization.prototype.apply = function (obj) { 1103 if(typeof obj.headers.Authorization === 'undefined') { 1104 obj.headers.Authorization = 'Basic ' + btoa(this.username + ':' + this.password); 1105 } 1106 1107 return true; 1108 }; 1109 1110 },{"./helpers":4,"btoa":14,"cookiejar":19,"lodash-compat/collection/each":56,"lodash-compat/collection/includes":59,"lodash-compat/lang/isArray":144,"lodash-compat/lang/isObject":148}],3:[function(require,module,exports){ 1111 'use strict'; 1112 1113 var _ = { 1114 bind: require('lodash-compat/function/bind'), 1115 cloneDeep: require('lodash-compat/lang/cloneDeep'), 1116 find: require('lodash-compat/collection/find'), 1117 forEach: require('lodash-compat/collection/forEach'), 1118 indexOf: require('lodash-compat/array/indexOf'), 1119 isArray: require('lodash-compat/lang/isArray'), 1120 isObject: require('lodash-compat/lang/isObject'), 1121 isFunction: require('lodash-compat/lang/isFunction'), 1122 isPlainObject: require('lodash-compat/lang/isPlainObject'), 1123 isUndefined: require('lodash-compat/lang/isUndefined') 1124 }; 1125 var auth = require('./auth'); 1126 var helpers = require('./helpers'); 1127 var Model = require('./types/model'); 1128 var Operation = require('./types/operation'); 1129 var OperationGroup = require('./types/operationGroup'); 1130 var Resolver = require('./resolver'); 1131 var SwaggerHttp = require('./http'); 1132 var SwaggerSpecConverter = require('./spec-converter'); 1133 var Q = require('q'); 1134 1135 // We have to keep track of the function/property names to avoid collisions for tag names which are used to allow the 1136 // following usage: 'client.{tagName}' 1137 var reservedClientTags = [ 1138 'apis', 1139 'authorizationScheme', 1140 'authorizations', 1141 'basePath', 1142 'build', 1143 'buildFrom1_1Spec', 1144 'buildFrom1_2Spec', 1145 'buildFromSpec', 1146 'clientAuthorizations', 1147 'convertInfo', 1148 'debug', 1149 'defaultErrorCallback', 1150 'defaultSuccessCallback', 1151 'enableCookies', 1152 'fail', 1153 'failure', 1154 'finish', 1155 'help', 1156 'idFromOp', 1157 'info', 1158 'initialize', 1159 'isBuilt', 1160 'isValid', 1161 'modelPropertyMacro', 1162 'models', 1163 'modelsArray', 1164 'options', 1165 'parameterMacro', 1166 'parseUri', 1167 'progress', 1168 'resourceCount', 1169 'sampleModels', 1170 'selfReflect', 1171 'setConsolidatedModels', 1172 'spec', 1173 'supportedSubmitMethods', 1174 'swaggerRequestHeaders', 1175 'tagFromLabel', 1176 'title', 1177 'url', 1178 'useJQuery' 1179 ]; 1180 // We have to keep track of the function/property names to avoid collisions for tag names which are used to allow the 1181 // following usage: 'client.apis.{tagName}' 1182 var reservedApiTags = [ 1183 'apis', 1184 'asCurl', 1185 'description', 1186 'externalDocs', 1187 'help', 1188 'label', 1189 'name', 1190 'operation', 1191 'operations', 1192 'operationsArray', 1193 'path', 1194 'tag' 1195 ]; 1196 var supportedOperationMethods = ['delete', 'get', 'head', 'options', 'patch', 'post', 'put']; 1197 var SwaggerClient = module.exports = function (url, options) { 1198 this.authorizations = null; 1199 this.authorizationScheme = null; 1200 this.basePath = null; 1201 this.debug = false; 1202 this.enableCookies = false; 1203 this.info = null; 1204 this.isBuilt = false; 1205 this.isValid = false; 1206 this.modelsArray = []; 1207 this.resourceCount = 0; 1208 this.url = null; 1209 this.useJQuery = false; 1210 this.swaggerObject = {}; 1211 this.deferredClient = Q.defer(); 1212 1213 this.clientAuthorizations = new auth.SwaggerAuthorizations(); 1214 1215 if (typeof url !== 'undefined') { 1216 return this.initialize(url, options); 1217 } else { 1218 return this; 1219 } 1220 }; 1221 1222 SwaggerClient.prototype.initialize = function (url, options) { 1223 this.models = {}; 1224 this.sampleModels = {}; 1225 1226 if (typeof url === 'string') { 1227 this.url = url; 1228 } else if (_.isObject(url)) { 1229 options = url; 1230 this.url = options.url; 1231 } 1232 1233 options = options || {}; 1234 this.clientAuthorizations.add(options.authorizations); 1235 this.swaggerRequestHeaders = options.swaggerRequestHeaders || 'application/json;charset=utf-8,*/*'; 1236 this.defaultSuccessCallback = options.defaultSuccessCallback || null; 1237 this.defaultErrorCallback = options.defaultErrorCallback || null; 1238 this.modelPropertyMacro = options.modelPropertyMacro || null; 1239 this.parameterMacro = options.parameterMacro || null; 1240 this.usePromise = options.usePromise || null; 1241 1242 if (typeof options.success === 'function') { 1243 this.success = options.success; 1244 } 1245 1246 if (options.useJQuery) { 1247 this.useJQuery = options.useJQuery; 1248 } 1249 1250 if (options.enableCookies) { 1251 this.enableCookies = options.enableCookies; 1252 } 1253 1254 this.options = options || {}; 1255 1256 this.supportedSubmitMethods = options.supportedSubmitMethods || []; 1257 this.failure = options.failure || function (err) { throw err; }; 1258 this.progress = options.progress || function () {}; 1259 this.spec = _.cloneDeep(options.spec); // Clone so we do not alter the provided document 1260 1261 if (options.scheme) { 1262 this.scheme = options.scheme; 1263 } 1264 1265 if (this.usePromise || typeof options.success === 'function') { 1266 this.ready = true; 1267 return this.build(); 1268 } 1269 }; 1270 1271 SwaggerClient.prototype.build = function (mock) { 1272 if (this.isBuilt) { 1273 return this; 1274 } 1275 1276 var self = this; 1277 1278 this.progress('fetching resource list: ' + this.url + '; Please wait.'); 1279 1280 var obj = { 1281 useJQuery: this.useJQuery, 1282 url: this.url, 1283 method: 'get', 1284 headers: { 1285 accept: this.swaggerRequestHeaders 1286 }, 1287 on: { 1288 error: function (response) { 1289 if (self.url.substring(0, 4) !== 'http') { 1290 return self.fail('Please specify the protocol for ' + self.url); 1291 } else if (response.status === 0) { 1292 return self.fail('Can\'t read from server. It may not have the appropriate access-control-origin settings.'); 1293 } else if (response.status === 404) { 1294 return self.fail('Can\'t read swagger JSON from ' + self.url); 1295 } else { 1296 return self.fail(response.status + ' : ' + response.statusText + ' ' + self.url); 1297 } 1298 }, 1299 response: function (resp) { 1300 1301 var responseObj = resp.obj; 1302 if(!responseObj) { 1303 return self.fail('failed to parse JSON/YAML response'); 1304 } 1305 1306 self.swaggerVersion = responseObj.swaggerVersion; 1307 self.swaggerObject = responseObj; 1308 1309 if (responseObj.swagger && parseInt(responseObj.swagger) === 2) { 1310 self.swaggerVersion = responseObj.swagger; 1311 1312 new Resolver().resolve(responseObj, self.url, self.buildFromSpec, self); 1313 1314 self.isValid = true; 1315 } else { 1316 var converter = new SwaggerSpecConverter(); 1317 self.oldSwaggerObject = self.swaggerObject; 1318 1319 converter.setDocumentationLocation(self.url); 1320 converter.convert(responseObj, self.clientAuthorizations, self.options, function(spec) { 1321 self.swaggerObject = spec; 1322 new Resolver().resolve(spec, self.url, self.buildFromSpec, self); 1323 self.isValid = true; 1324 }); 1325 } 1326 } 1327 } 1328 }; 1329 1330 if (this.spec) { 1331 self.swaggerObject = this.spec; 1332 setTimeout(function () { 1333 new Resolver().resolve(self.spec, self.buildFromSpec, self); 1334 }, 10); 1335 } else { 1336 this.clientAuthorizations.apply(obj); 1337 1338 if (mock) { 1339 return obj; 1340 } 1341 1342 new SwaggerHttp().execute(obj, this.options); 1343 } 1344 1345 return (this.usePromise) ? this.deferredClient.promise : this; 1346 }; 1347 1348 SwaggerClient.prototype.buildFromSpec = function (response) { 1349 if (this.isBuilt) { 1350 return this; 1351 } 1352 1353 this.apis = {}; 1354 this.apisArray = []; 1355 this.basePath = response.basePath || ''; 1356 this.consumes = response.consumes; 1357 this.host = response.host || ''; 1358 this.info = response.info || {}; 1359 this.produces = response.produces; 1360 this.schemes = response.schemes || []; 1361 this.securityDefinitions = response.securityDefinitions; 1362 this.title = response.title || ''; 1363 1364 if (response.externalDocs) { 1365 this.externalDocs = response.externalDocs; 1366 } 1367 1368 // legacy support 1369 this.authSchemes = response.securityDefinitions; 1370 1371 var definedTags = {}; 1372 var k; 1373 1374 if (Array.isArray(response.tags)) { 1375 definedTags = {}; 1376 1377 for (k = 0; k < response.tags.length; k++) { 1378 var t = response.tags[k]; 1379 definedTags[t.name] = t; 1380 } 1381 } 1382 1383 var location; 1384 1385 if (typeof this.url === 'string') { 1386 location = this.parseUri(this.url); 1387 if (typeof this.scheme === 'undefined' && typeof this.schemes === 'undefined' || this.schemes.length === 0) { 1388 this.scheme = location.scheme || 'http'; 1389 } else if (typeof this.scheme === 'undefined') { 1390 this.scheme = this.schemes[0] || location.scheme; 1391 } 1392 1393 if (typeof this.host === 'undefined' || this.host === '') { 1394 this.host = location.host; 1395 1396 if (location.port) { 1397 this.host = this.host + ':' + location.port; 1398 } 1399 } 1400 } 1401 else { 1402 if (typeof this.schemes === 'undefined' || this.schemes.length === 0) { 1403 this.scheme = 'http'; 1404 } 1405 else if (typeof this.scheme === 'undefined') { 1406 this.scheme = this.schemes[0]; 1407 } 1408 } 1409 1410 this.definitions = response.definitions; 1411 1412 var key; 1413 1414 for (key in this.definitions) { 1415 var model = new Model(key, this.definitions[key], this.models, this.modelPropertyMacro); 1416 1417 if (model) { 1418 this.models[key] = model; 1419 } 1420 } 1421 1422 // get paths, create functions for each operationId 1423 var self = this; 1424 1425 // Bind help to 'client.apis' 1426 self.apis.help = _.bind(self.help, self); 1427 1428 _.forEach(response.paths, function (pathObj, path) { 1429 // Only process a path if it's an object 1430 if (!_.isPlainObject(pathObj)) { 1431 return; 1432 } 1433 1434 _.forEach(supportedOperationMethods, function (method) { 1435 var operation = pathObj[method]; 1436 1437 if (_.isUndefined(operation)) { 1438 // Operation does not exist 1439 return; 1440 } else if (!_.isPlainObject(operation)) { 1441 // Operation exists but it is not an Operation Object. Since this is invalid, log it. 1442 helpers.log('The \'' + method + '\' operation for \'' + path + '\' path is not an Operation Object'); 1443 1444 return; 1445 } 1446 1447 var tags = operation.tags; 1448 1449 if (_.isUndefined(tags) || !_.isArray(tags) || tags.length === 0) { 1450 tags = operation.tags = [ 'default' ]; 1451 } 1452 1453 var operationId = self.idFromOp(path, method, operation); 1454 1455 var operationObject = new Operation(self, 1456 operation.scheme, 1457 operationId, 1458 method, 1459 path, 1460 operation, 1461 self.definitions, 1462 self.models, 1463 self.clientAuthorizations); 1464 1465 // bind self operation's execute command to the api 1466 _.forEach(tags, function (tag) { 1467 var clientProperty = _.indexOf(reservedClientTags, tag) > -1 ? '_' + tag : tag; 1468 var apiProperty = _.indexOf(reservedApiTags, tag) > -1 ? '_' + tag : tag; 1469 var operationGroup = self[clientProperty]; 1470 1471 if (clientProperty !== tag) { 1472 helpers.log('The \'' + tag + '\' tag conflicts with a SwaggerClient function/property name. Use \'client.' + 1473 clientProperty + '\' or \'client.apis.' + tag + '\' instead of \'client.' + tag + '\'.'); 1474 } 1475 1476 if (apiProperty !== tag) { 1477 helpers.log('The \'' + tag + '\' tag conflicts with a SwaggerClient operation function/property name. Use ' + 1478 '\'client.apis.' + apiProperty + '\' instead of \'client.apis.' + tag + '\'.'); 1479 } 1480 1481 if (_.indexOf(reservedApiTags, operationId) > -1) { 1482 helpers.log('The \'' + operationId + '\' operationId conflicts with a SwaggerClient operation ' + 1483 'function/property name. Use \'client.apis.' + apiProperty + '._' + operationId + 1484 '\' instead of \'client.apis.' + apiProperty + '.' + operationId + '\'.'); 1485 1486 operationId = '_' + operationId; 1487 operationObject.nickname = operationId; // So 'client.apis.[tag].operationId.help() works properly 1488 } 1489 1490 if (_.isUndefined(operationGroup)) { 1491 operationGroup = self[clientProperty] = self.apis[apiProperty] = {}; 1492 1493 operationGroup.operations = {}; 1494 operationGroup.label = apiProperty; 1495 operationGroup.apis = {}; 1496 1497 var tagDef = definedTags[tag]; 1498 1499 if (!_.isUndefined(tagDef)) { 1500 operationGroup.description = tagDef.description; 1501 operationGroup.externalDocs = tagDef.externalDocs; 1502 } 1503 1504 self[clientProperty].help = _.bind(self.help, operationGroup); 1505 self.apisArray.push(new OperationGroup(tag, operationGroup.description, operationGroup.externalDocs, operationObject)); 1506 } 1507 1508 operationId = self.makeUniqueOperationId(operationId, self.apis[apiProperty]); 1509 1510 // Bind tag help 1511 if (!_.isFunction(operationGroup.help)) { 1512 operationGroup.help = _.bind(self.help, operationGroup); 1513 } 1514 1515 // bind to the apis object 1516 self.apis[apiProperty][operationId] = operationGroup[operationId] = _.bind(operationObject.execute, 1517 operationObject); 1518 self.apis[apiProperty][operationId].help = operationGroup[operationId].help = _.bind(operationObject.help, 1519 operationObject); 1520 self.apis[apiProperty][operationId].asCurl = operationGroup[operationId].asCurl = _.bind(operationObject.asCurl, 1521 operationObject); 1522 1523 operationGroup.apis[operationId] = operationGroup.operations[operationId] = operationObject; 1524 1525 // legacy UI feature 1526 var api = _.find(self.apisArray, function (api) { 1527 return api.tag === tag; 1528 }); 1529 1530 if (api) { 1531 api.operationsArray.push(operationObject); 1532 } 1533 }); 1534 }); 1535 }); 1536 1537 this.isBuilt = true; 1538 1539 if (this.usePromise) { 1540 this.isValid = true; 1541 this.isBuilt = true; 1542 this.deferredClient.resolve(this); 1543 1544 return this.deferredClient.promise; 1545 } 1546 1547 if (this.success) { 1548 this.success(); 1549 } 1550 1551 return this; 1552 }; 1553 1554 SwaggerClient.prototype.makeUniqueOperationId = function(operationId, api) { 1555 var count = 0; 1556 var name = operationId; 1557 1558 // make unique across this operation group 1559 while(true) { 1560 var matched = false; 1561 _.forEach(api.operations, function (operation) { 1562 if(operation.nickname === name) { 1563 matched = true; 1564 } 1565 }); 1566 if(!matched) { 1567 return name; 1568 } 1569 name = operationId + '_' + count; 1570 count ++; 1571 } 1572 1573 return operationId; 1574 }; 1575 1576 SwaggerClient.prototype.parseUri = function (uri) { 1577 var urlParseRE = /^(((([^:\/#\?]+:)?(?:(\/\/)((?:(([^:@\/#\?]+)(?:\:([^:@\/#\?]+))?)@)?(([^:\/#\?\]\[]+|\[[^\/\]@#?]+\])(?:\:([0-9]+))?))?)?)?((\/?(?:[^\/\?#]+\/+)*)([^\?#]*)))?(\?[^#]+)?)(#.*)?/; 1578 var parts = urlParseRE.exec(uri); 1579 1580 return { 1581 scheme: parts[4] ? parts[4].replace(':','') : undefined, 1582 host: parts[11], 1583 port: parts[12], 1584 path: parts[15] 1585 }; 1586 }; 1587 1588 SwaggerClient.prototype.help = function (dontPrint) { 1589 var output = ''; 1590 1591 if (this instanceof SwaggerClient) { 1592 _.forEach(this.apis, function (api, name) { 1593 if (_.isPlainObject(api)) { 1594 output += 'operations for the \'' + name + '\' tag\n'; 1595 1596 _.forEach(api.operations, function (operation, name) { 1597 output += ' * ' + name + ': ' + operation.summary + '\n'; 1598 }); 1599 } 1600 }); 1601 } else if (this instanceof OperationGroup || _.isPlainObject(this)) { 1602 output += 'operations for the \'' + this.label + '\' tag\n'; 1603 1604 _.forEach(this.apis, function (operation, name) { 1605 output += ' * ' + name + ': ' + operation.summary + '\n'; 1606 }); 1607 } 1608 1609 if (dontPrint) { 1610 return output; 1611 } else { 1612 helpers.log(output); 1613 1614 return output; 1615 } 1616 }; 1617 1618 SwaggerClient.prototype.tagFromLabel = function (label) { 1619 return label; 1620 }; 1621 1622 SwaggerClient.prototype.idFromOp = function (path, httpMethod, op) { 1623 if(!op || !op.operationId) { 1624 op = op || {}; 1625 op.operationId = httpMethod + '_' + path; 1626 } 1627 var opId = op.operationId.replace(/[\s!@#$%^&*()_+=\[{\]};:<>|.\/?,\\'""-]/g, '_') || (path.substring(1) + '_' + httpMethod); 1628 1629 opId = opId.replace(/((_){2,})/g, '_'); 1630 opId = opId.replace(/^(_)*/g, ''); 1631 opId = opId.replace(/([_])*$/g, ''); 1632 1633 return opId; 1634 }; 1635 1636 SwaggerClient.prototype.setHost = function (host) { 1637 this.host = host; 1638 1639 if(this.apis) { 1640 _.forEach(this.apis, function(api) { 1641 if(api.operations) { 1642 _.forEach(api.operations, function(operation) { 1643 operation.host = host; 1644 }); 1645 } 1646 }); 1647 } 1648 }; 1649 1650 SwaggerClient.prototype.setBasePath = function (basePath) { 1651 this.basePath = basePath; 1652 1653 if(this.apis) { 1654 _.forEach(this.apis, function(api) { 1655 if(api.operations) { 1656 _.forEach(api.operations, function(operation) { 1657 operation.basePath = basePath; 1658 }); 1659 } 1660 }); 1661 } 1662 }; 1663 1664 SwaggerClient.prototype.fail = function (message) { 1665 if (this.usePromise) { 1666 this.deferredClient.reject(message); 1667 return this.deferredClient.promise; 1668 } else { 1669 if (this.failure) { 1670 this.failure(message); 1671 } 1672 else { 1673 this.failure(message); 1674 } 1675 } 1676 }; 1677 1678 },{"./auth":2,"./helpers":4,"./http":5,"./resolver":6,"./spec-converter":8,"./types/model":9,"./types/operation":10,"./types/operationGroup":11,"lodash-compat/array/indexOf":53,"lodash-compat/collection/find":57,"lodash-compat/collection/forEach":58,"lodash-compat/function/bind":62,"lodash-compat/lang/cloneDeep":142,"lodash-compat/lang/isArray":144,"lodash-compat/lang/isFunction":146,"lodash-compat/lang/isObject":148,"lodash-compat/lang/isPlainObject":149,"lodash-compat/lang/isUndefined":152,"q":161}],4:[function(require,module,exports){ 1679 (function (process){ 1680 'use strict'; 1681 1682 var _ = { 1683 isPlainObject: require('lodash-compat/lang/isPlainObject'), 1684 indexOf: require('lodash-compat/array/indexOf') 1685 }; 1686 1687 module.exports.__bind = function (fn, me) { 1688 return function(){ 1689 return fn.apply(me, arguments); 1690 }; 1691 }; 1692 1693 var log = module.exports.log = function() { 1694 // Only log if available and we're not testing 1695 if (console && process.env.NODE_ENV !== 'test') { 1696 console.log(Array.prototype.slice.call(arguments)[0]); 1697 } 1698 }; 1699 1700 module.exports.fail = function (message) { 1701 log(message); 1702 }; 1703 1704 var optionHtml = module.exports.optionHtml = function (label, value) { 1705 return '<tr><td class="optionName">' + label + ':</td><td>' + value + '</td></tr>'; 1706 }; 1707 1708 var resolveSchema = module.exports.resolveSchema = function (schema) { 1709 if (_.isPlainObject(schema.schema)) { 1710 schema = resolveSchema(schema.schema); 1711 } 1712 1713 return schema; 1714 }; 1715 1716 var simpleRef = module.exports.simpleRef = function (name) { 1717 if (typeof name === 'undefined') { 1718 return null; 1719 } 1720 1721 if (name.indexOf('#/definitions/') === 0) { 1722 return name.substring('#/definitions/'.length); 1723 } else { 1724 return name; 1725 } 1726 }; 1727 1728 1729 }).call(this,require('_process')) 1730 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9oZWxwZXJzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgXyA9IHtcbiAgaXNQbGFpbk9iamVjdDogcmVxdWlyZSgnbG9kYXNoLWNvbXBhdC9sYW5nL2lzUGxhaW5PYmplY3QnKSxcbiAgaW5kZXhPZjogcmVxdWlyZSgnbG9kYXNoLWNvbXBhdC9hcnJheS9pbmRleE9mJylcbn07XG5cbm1vZHVsZS5leHBvcnRzLl9fYmluZCA9IGZ1bmN0aW9uIChmbiwgbWUpIHtcbiAgcmV0dXJuIGZ1bmN0aW9uKCl7XG4gICAgcmV0dXJuIGZuLmFwcGx5KG1lLCBhcmd1bWVudHMpO1xuICB9O1xufTtcblxudmFyIGxvZyA9IG1vZHVsZS5leHBvcnRzLmxvZyA9IGZ1bmN0aW9uKCkge1xuICAvLyBPbmx5IGxvZyBpZiBhdmFpbGFibGUgYW5kIHdlJ3JlIG5vdCB0ZXN0aW5nXG4gIGlmIChjb25zb2xlICYmIHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAndGVzdCcpIHtcbiAgICBjb25zb2xlLmxvZyhBcnJheS5wcm90b3R5cGUuc2xpY2UuY2FsbChhcmd1bWVudHMpWzBdKTtcbiAgfVxufTtcblxubW9kdWxlLmV4cG9ydHMuZmFpbCA9IGZ1bmN0aW9uIChtZXNzYWdlKSB7XG4gIGxvZyhtZXNzYWdlKTtcbn07XG5cbnZhciBvcHRpb25IdG1sID0gbW9kdWxlLmV4cG9ydHMub3B0aW9uSHRtbCA9IGZ1bmN0aW9uIChsYWJlbCwgdmFsdWUpIHtcbiAgcmV0dXJuICc8dHI+PHRkIGNsYXNzPVwib3B0aW9uTmFtZVwiPicgKyBsYWJlbCArICc6PC90ZD48dGQ+JyArIHZhbHVlICsgJzwvdGQ+PC90cj4nO1xufTtcblxudmFyIHJlc29sdmVTY2hlbWEgPSBtb2R1bGUuZXhwb3J0cy5yZXNvbHZlU2NoZW1hID0gZnVuY3Rpb24gKHNjaGVtYSkge1xuICBpZiAoXy5pc1BsYWluT2JqZWN0KHNjaGVtYS5zY2hlbWEpKSB7XG4gICAgc2NoZW1hID0gcmVzb2x2ZVNjaGVtYShzY2hlbWEuc2NoZW1hKTtcbiAgfVxuXG4gIHJldHVybiBzY2hlbWE7XG59O1xuXG52YXIgc2ltcGxlUmVmID0gbW9kdWxlLmV4cG9ydHMuc2ltcGxlUmVmID0gZnVuY3Rpb24gKG5hbWUpIHtcbiAgaWYgKHR5cGVvZiBuYW1lID09PSAndW5kZWZpbmVkJykge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgaWYgKG5hbWUuaW5kZXhPZignIy9kZWZpbml0aW9ucy8nKSA9PT0gMCkge1xuICAgIHJldHVybiBuYW1lLnN1YnN0cmluZygnIy9kZWZpbml0aW9ucy8nLmxlbmd0aCk7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIG5hbWU7XG4gIH1cbn07XG5cbiJdfQ== 1731 },{"_process":13,"lodash-compat/array/indexOf":53,"lodash-compat/lang/isPlainObject":149}],5:[function(require,module,exports){ 1732 'use strict'; 1733 1734 var helpers = require('./helpers'); 1735 var request = require('superagent'); 1736 var jsyaml = require('js-yaml'); 1737 var _ = { 1738 isObject: require('lodash-compat/lang/isObject') 1739 }; 1740 1741 /* 1742 * JQueryHttpClient is a light-weight, node or browser HTTP client 1743 */ 1744 var JQueryHttpClient = function () {}; 1745 1746 /* 1747 * SuperagentHttpClient is a light-weight, node or browser HTTP client 1748 */ 1749 var SuperagentHttpClient = function () {}; 1750 1751 /** 1752 * SwaggerHttp is a wrapper for executing requests 1753 */ 1754 var SwaggerHttp = module.exports = function () {}; 1755 1756 SwaggerHttp.prototype.execute = function (obj, opts) { 1757 var client; 1758 1759 if(opts && opts.client) { 1760 client = opts.client; 1761 } 1762 else { 1763 client = new SuperagentHttpClient(opts); 1764 } 1765 client.opts = opts || {}; 1766 1767 // legacy support 1768 var hasJQuery = false; 1769 if(typeof window !== 'undefined') { 1770 if(typeof window.jQuery !== 'undefined') { 1771 hasJQuery = true; 1772 } 1773 } 1774 if(this.isInternetExplorer() && (obj.useJQuery === false || !hasJQuery )) { 1775 throw new Error('Unsupported configuration! JQuery is required but not available'); 1776 } 1777 if ((obj && obj.useJQuery === true) || this.isInternetExplorer() && hasJQuery) { 1778 client = new JQueryHttpClient(opts); 1779 } 1780 1781 var success = obj.on.response; 1782 1783 var requestInterceptor = function(data) { 1784 if(opts && opts.requestInterceptor) { 1785 data = opts.requestInterceptor.apply(data); 1786 } 1787 return data; 1788 }; 1789 1790 var responseInterceptor = function(data) { 1791 if(opts && opts.responseInterceptor) { 1792 data = opts.responseInterceptor.apply(data); 1793 } 1794 return success(data); 1795 }; 1796 1797 obj.on.response = function(data) { 1798 responseInterceptor(data); 1799 }; 1800 1801 1802 if (_.isObject(obj) && _.isObject(obj.body)) { 1803 // special processing for file uploads via jquery 1804 if (obj.body.type && obj.body.type === 'formData'){ 1805 obj.contentType = false; 1806 obj.processData = false; 1807 1808 delete obj.headers['Content-Type']; 1809 } else { 1810 obj.body = JSON.stringify(obj.body); 1811 } 1812 } 1813 1814 client.execute(requestInterceptor(obj)); 1815 1816 return (obj.deferred) ? obj.deferred.promise : obj; 1817 }; 1818 1819 SwaggerHttp.prototype.isInternetExplorer = function () { 1820 var detectedIE = false; 1821 1822 if (typeof navigator !== 'undefined' && navigator.userAgent) { 1823 var nav = navigator.userAgent.toLowerCase(); 1824 1825 if (nav.indexOf('msie') !== -1) { 1826 var version = parseInt(nav.split('msie')[1]); 1827 1828 if (version <= 8) { 1829 detectedIE = true; 1830 } 1831 } 1832 } 1833 1834 return detectedIE; 1835 }; 1836 1837 JQueryHttpClient.prototype.execute = function (obj) { 1838 var jq = this.jQuery || window.jQuery; 1839 var cb = obj.on; 1840 var request = obj; 1841 1842 obj.type = obj.method; 1843 obj.cache = false; 1844 delete obj.useJQuery; 1845 1846 /* 1847 obj.beforeSend = function (xhr) { 1848 var key, results; 1849 if (obj.headers) { 1850 results = []; 1851 for (key in obj.headers) { 1852 if (key.toLowerCase() === 'content-type') { 1853 results.push(obj.contentType = obj.headers[key]); 1854 } else if (key.toLowerCase() === 'accept') { 1855 results.push(obj.accepts = obj.headers[key]); 1856 } else { 1857 results.push(xhr.setRequestHeader(key, obj.headers[key])); 1858 } 1859 } 1860 return results; 1861 } 1862 };*/ 1863 1864 obj.data = obj.body; 1865 1866 delete obj.body; 1867 1868 obj.complete = function (response) { 1869 var headers = {}; 1870 var headerArray = response.getAllResponseHeaders().split('\n'); 1871 1872 for (var i = 0; i < headerArray.length; i++) { 1873 var toSplit = headerArray[i].trim(); 1874 1875 if (toSplit.length === 0) { 1876 continue; 1877 } 1878 1879 var separator = toSplit.indexOf(':'); 1880 1881 if (separator === -1) { 1882 // Name but no value in the header 1883 headers[toSplit] = null; 1884 1885 continue; 1886 } 1887 1888 var name = toSplit.substring(0, separator).trim(); 1889 var value = toSplit.substring(separator + 1).trim(); 1890 1891 headers[name] = value; 1892 } 1893 1894 var out = { 1895 url: request.url, 1896 method: request.method, 1897 status: response.status, 1898 statusText: response.statusText, 1899 data: response.responseText, 1900 headers: headers 1901 }; 1902 1903 try { 1904 var possibleObj = response.responseJSON || jsyaml.safeLoad(response.responseText); 1905 out.obj = (typeof possibleObj === 'string') ? {} : possibleObj; 1906 } catch (ex) { 1907 // do not set out.obj 1908 helpers.log('unable to parse JSON/YAML content'); 1909 } 1910 1911 // I can throw, or parse null? 1912 out.obj = out.obj || null; 1913 1914 if (response.status >= 200 && response.status < 300) { 1915 cb.response(out); 1916 } else if (response.status === 0 || (response.status >= 400 && response.status < 599)) { 1917 cb.error(out); 1918 } else { 1919 return cb.response(out); 1920 } 1921 }; 1922 1923 jq.support.cors = true; 1924 1925 return jq.ajax(obj); 1926 }; 1927 1928 SuperagentHttpClient.prototype.execute = function (obj) { 1929 var method = obj.method.toLowerCase(); 1930 1931 if (method === 'delete') { 1932 method = 'del'; 1933 } 1934 var headers = obj.headers || {}; 1935 var r = request[method](obj.url); 1936 var name; 1937 for (name in headers) { 1938 r.set(name, headers[name]); 1939 } 1940 1941 if (obj.enableCookies) { 1942 r.withCredentials(); 1943 } 1944 1945 if (obj.body) { 1946 r.send(obj.body); 1947 } 1948 1949 if(typeof r.buffer === 'function') { 1950 r.buffer(); // force superagent to populate res.text with the raw response data 1951 } 1952 1953 r.end(function (err, res) { 1954 res = res || { 1955 status: 0, 1956 headers: {error: 'no response from server'} 1957 }; 1958 var response = { 1959 url: obj.url, 1960 method: obj.method, 1961 headers: res.headers 1962 }; 1963 var cb; 1964 1965 if (!err && res.error) { 1966 err = res.error; 1967 } 1968 1969 if (err && obj.on && obj.on.error) { 1970 response.errObj = err; 1971 response.status = res ? res.status : 500; 1972 response.statusText = res ? res.text : err.message; 1973 if(res.headers && res.headers['content-type']) { 1974 if(res.headers['content-type'].indexOf('application/json') >= 0) { 1975 try { 1976 response.obj = JSON.parse(response.statusText); 1977 } 1978 catch (e) { 1979 response.obj = null; 1980 } 1981 } 1982 } 1983 cb = obj.on.error; 1984 } else if (res && obj.on && obj.on.response) { 1985 var possibleObj; 1986 1987 // Already parsed by by superagent? 1988 if(res.body && Object.keys(res.body).length > 0) { 1989 possibleObj = res.body; 1990 } else { 1991 try { 1992 possibleObj = jsyaml.safeLoad(res.text); 1993 // can parse into a string... which we don't need running around in the system 1994 possibleObj = (typeof possibleObj === 'string') ? null : possibleObj; 1995 } catch(e) { 1996 helpers.log('cannot parse JSON/YAML content'); 1997 } 1998 } 1999 2000 // null means we can't parse into object 2001 response.obj = (typeof possibleObj === 'object') ? possibleObj : null; 2002 2003 response.status = res.status; 2004 response.statusText = res.text; 2005 cb = obj.on.response; 2006 } 2007 response.data = response.statusText; 2008 2009 if (cb) { 2010 cb(response); 2011 } 2012 }); 2013 }; 2014 2015 },{"./helpers":4,"js-yaml":20,"lodash-compat/lang/isObject":148,"superagent":162}],6:[function(require,module,exports){ 2016 'use strict'; 2017 2018 var SwaggerHttp = require('./http'); 2019 var _ = { 2020 isObject: require('lodash-compat/lang/isObject'), 2021 cloneDeep: require('lodash-compat/lang/cloneDeep'), 2022 isArray: require('lodash-compat/lang/isArray') 2023 }; 2024 2025 2026 /** 2027 * Resolves a spec's remote references 2028 */ 2029 var Resolver = module.exports = function () {}; 2030 2031 Resolver.prototype.processAllOf = function(root, name, definition, resolutionTable, unresolvedRefs, spec) { 2032 var i, location, property; 2033 2034 definition['x-resolved-from'] = [ '#/definitions/' + name ]; 2035 var allOf = definition.allOf; 2036 // the refs go first 2037 allOf.sort(function(a, b) { 2038 if(a.$ref && b.$ref) { return 0; } 2039 else if(a.$ref) { return -1; } 2040 else { return 1; } 2041 }); 2042 for (i = 0; i < allOf.length; i++) { 2043 property = allOf[i]; 2044 location = '/definitions/' + name + '/allOf'; 2045 this.resolveInline(root, spec, property, resolutionTable, unresolvedRefs, location); 2046 } 2047 }; 2048 2049 Resolver.prototype.resolve = function (spec, arg1, arg2, arg3) { 2050 this.spec = spec; 2051 var root = arg1, callback = arg2, scope = arg3, opts = {}, location, i; 2052 if(typeof arg1 === 'function') { 2053 root = null; 2054 callback = arg1; 2055 scope = arg2; 2056 } 2057 var _root = root; 2058 this.scope = (scope || this); 2059 this.iteration = this.iteration || 0; 2060 2061 if(this.scope.options && this.scope.options.requestInterceptor){ 2062 opts.requestInterceptor = this.scope.options.requestInterceptor; 2063 } 2064 2065 if(this.scope.options && this.scope.options.responseInterceptor){ 2066 opts.responseInterceptor = this.scope.options.responseInterceptor; 2067 } 2068 2069 var name, path, property, propertyName; 2070 var processedCalls = 0, resolvedRefs = {}, unresolvedRefs = {}; 2071 var resolutionTable = []; // store objects for dereferencing 2072 2073 spec.definitions = spec.definitions || {}; 2074 // definitions 2075 for (name in spec.definitions) { 2076 var definition = spec.definitions[name]; 2077 for (propertyName in definition.properties) { 2078 property = definition.properties[propertyName]; 2079 if(_.isArray(property.allOf)) { 2080 this.processAllOf(root, name, property, resolutionTable, unresolvedRefs, spec); 2081 } 2082 else { 2083 this.resolveTo(root, property, resolutionTable, '/definitions'); 2084 } 2085 } 2086 2087 if(definition.allOf) { 2088 this.processAllOf(root, name, definition, resolutionTable, unresolvedRefs, spec); 2089 } 2090 } 2091 2092 // operations 2093 for (name in spec.paths) { 2094 var method, operation, responseCode; 2095 path = spec.paths[name]; 2096 2097 for (method in path) { 2098 // operation reference 2099 if(method === '$ref') { 2100 // location = path[method]; 2101 location = '/paths' + name; 2102 this.resolveInline(root, spec, path, resolutionTable, unresolvedRefs, location); 2103 } 2104 else { 2105 operation = path[method]; 2106 var sharedParameters = path.parameters || []; 2107 var parameters = operation.parameters || []; 2108 2109 for (i in sharedParameters) { 2110 var parameter = sharedParameters[i]; 2111 parameters.unshift(parameter); 2112 } 2113 if(method !== 'parameters' && _.isObject(operation)) { 2114 operation.parameters = operation.parameters || parameters; 2115 } 2116 2117 for (i in parameters) { 2118 var parameter = parameters[i]; 2119 location = '/paths' + name + '/' + method + '/parameters'; 2120 2121 if (parameter.in === 'body' && parameter.schema) { 2122 if(_.isArray(parameter.schema.allOf)) { 2123 // move to a definition 2124 var modelName = 'inline_model'; 2125 var name = modelName; 2126 var done = false; var counter = 0; 2127 while(!done) { 2128 if(typeof spec.definitions[name] === 'undefined') { 2129 done = true; 2130 break; 2131 } 2132 name = modelName + '_' + counter; 2133 counter ++; 2134 } 2135 spec.definitions[name] = { allOf: parameter.schema.allOf }; 2136 delete parameter.schema.allOf; 2137 parameter.schema.$ref = '#/definitions/' + name; 2138 this.processAllOf(root, name, spec.definitions[name], resolutionTable, unresolvedRefs, spec); 2139 } 2140 else { 2141 this.resolveTo(root, parameter.schema, resolutionTable, location); 2142 } 2143 } 2144 2145 if (parameter.$ref) { 2146 // parameter reference 2147 this.resolveInline(root, spec, parameter, resolutionTable, unresolvedRefs, parameter.$ref); 2148 } 2149 } 2150 2151 for (responseCode in operation.responses) { 2152 var response = operation.responses[responseCode]; 2153 location = '/paths' + name + '/' + method + '/responses/' + responseCode; 2154 2155 if(_.isObject(response)) { 2156 if(response.$ref) { 2157 // response reference 2158 this.resolveInline(root, spec, response, resolutionTable, unresolvedRefs, location); 2159 } 2160 if (response.schema) { 2161 this.resolveTo(root, response.schema, resolutionTable, location); 2162 } 2163 } 2164 } 2165 } 2166 } 2167 // clear them out to avoid multiple resolutions 2168 path.parameters = []; 2169 } 2170 2171 var expectedCalls = 0, toResolve = []; 2172 // if the root is same as obj[i].root we can resolve locally 2173 var all = resolutionTable; 2174 2175 var parts; 2176 for(i = 0; i < all.length; i++) { 2177 var a = all[i]; 2178 if(root === a.root) { 2179 if(a.resolveAs === 'ref') { 2180 // resolve any path walking 2181 var joined = ((a.root || '') + '/' + a.key).split('/'); 2182 var normalized = []; 2183 var url = ''; 2184 var k; 2185 2186 if(a.key.indexOf('../') >= 0) { 2187 for(var j = 0; j < joined.length; j++) { 2188 if(joined[j] === '..') { 2189 normalized = normalized.slice(0, normalized.length-1); 2190 } 2191 else { 2192 normalized.push(joined[j]); 2193 } 2194 } 2195 for(k = 0; k < normalized.length; k ++) { 2196 if(k > 0) { 2197 url += '/'; 2198 } 2199 url += normalized[k]; 2200 } 2201 // we now have to remote resolve this because the path has changed 2202 a.root = url; 2203 toResolve.push(a); 2204 } 2205 else { 2206 parts = a.key.split('#'); 2207 if(parts.length === 2) { 2208 if(parts[0].indexOf('http://') === 0 || parts[0].indexOf('https://') === 0) { 2209 a.root = parts[0]; 2210 } 2211 location = parts[1].split('/'); 2212 var r; 2213 var s = spec; 2214 for(k = 0; k < location.length; k++) { 2215 var part = location[k]; 2216 if(part !== '') { 2217 s = s[part]; 2218 if(typeof s !== 'undefined') { 2219 r = s; 2220 } 2221 else { 2222 r = null; 2223 break; 2224 } 2225 } 2226 } 2227 if(r === null) { 2228 // must resolve this too 2229 toResolve.push(a); 2230 } 2231 } 2232 } 2233 } 2234 else { 2235 if (a.resolveAs === 'inline') { 2236 if(a.key && a.key.indexOf('#') === -1 && a.key.charAt(0) !== '/') { 2237 // handle relative schema 2238 parts = a.root.split('/'); 2239 location = ''; 2240 for(i = 0; i < parts.length - 1; i++) { 2241 location += parts[i] + '/'; 2242 } 2243 location += a.key; 2244 a.root = location; 2245 a.location = ''; 2246 } 2247 toResolve.push(a); 2248 } 2249 } 2250 } 2251 else { 2252 toResolve.push(a); 2253 } 2254 } 2255 expectedCalls = toResolve.length; 2256 2257 // resolve anything that is local 2258 for(var ii = 0; ii < toResolve.length; ii++) { 2259 (function(item, spec, self) { 2260 if(item.root === null || item.root === root) { 2261 // local resolve 2262 self.resolveItem(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, item); 2263 processedCalls += 1; 2264 2265 if(processedCalls === expectedCalls) { 2266 self.finish(spec, root, resolutionTable, resolvedRefs, unresolvedRefs, callback, true); 2267 } 2268 } 2269 else { 2270 var obj = { 2271 useJQuery: false, // TODO 2272 url: item.root, 2273 method: 'get', 2274 headers: { 2275 accept: self.scope.swaggerRequestHeaders || 'application/json' 2276 }, 2277 on: { 2278 error: function (error) { 2279 processedCalls += 1; 2280 unresolvedRefs[item.key] = { 2281 root: item.root, 2282 location: item.location 2283 }; 2284 2285 if (processedCalls === expectedCalls) { 2286 self.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback); 2287 } 2288 }, // jshint ignore:line 2289 response: function (response) { 2290 var swagger = response.obj; 2291 self.resolveItem(swagger, item.root, resolutionTable, resolvedRefs, unresolvedRefs, item); 2292 processedCalls += 1; 2293 2294 if (processedCalls === expectedCalls) { 2295 self.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback); 2296 } 2297 } 2298 } // jshint ignore:line 2299 }; 2300 2301 if (scope && scope.clientAuthorizations) { 2302 scope.clientAuthorizations.apply(obj); 2303 } 2304 2305 new SwaggerHttp().execute(obj, opts); 2306 } 2307 }(toResolve[ii], spec, this)); 2308 } 2309 2310 if (Object.keys(toResolve).length === 0) { 2311 this.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback); 2312 } 2313 }; 2314 2315 Resolver.prototype.resolveItem = function(spec, root, resolutionTable, resolvedRefs, unresolvedRefs, item) { 2316 var path = item.location; 2317 var location = spec, parts = path.split('/'); 2318 if(path !== '') { 2319 for (var j = 0; j < parts.length; j++) { 2320 var segment = parts[j]; 2321 if (segment.indexOf('~1') !== -1) { 2322 segment = parts[j].replace(/~0/g, '~').replace(/~1/g, '/'); 2323 if (segment.charAt(0) !== '/') { 2324 segment = '/' + segment; 2325 } 2326 } 2327 if (typeof location === 'undefined' || location === null) { 2328 break; 2329 } 2330 if (segment === '' && j === (parts.length - 1) && parts.length > 1) { 2331 location = null; 2332 break; 2333 } 2334 if (segment.length > 0) { 2335 location = location[segment]; 2336 } 2337 } 2338 } 2339 var resolved = item.key; 2340 parts = item.key.split('/'); 2341 var resolvedName = parts[parts.length-1]; 2342 2343 if(resolvedName.indexOf('#') >= 0) { 2344 resolvedName = resolvedName.split('#')[1]; 2345 } 2346 2347 if (location !== null && typeof location !== 'undefined') { 2348 resolvedRefs[resolved] = { 2349 name: resolvedName, 2350 obj: location, 2351 key: item.key, 2352 root: item.root 2353 }; 2354 } else { 2355 unresolvedRefs[resolved] = { 2356 root: item.root, 2357 location: item.location 2358 }; 2359 } 2360 }; 2361 2362 Resolver.prototype.finish = function (spec, root, resolutionTable, resolvedRefs, unresolvedRefs, callback, localResolve) { 2363 // walk resolution table and replace with resolved refs 2364 var ref; 2365 for (ref in resolutionTable) { 2366 var item = resolutionTable[ref]; 2367 2368 var key = item.key; 2369 var resolvedTo = resolvedRefs[key]; 2370 if (resolvedTo) { 2371 spec.definitions = spec.definitions || {}; 2372 if (item.resolveAs === 'ref') { 2373 if (localResolve !== true) { 2374 // don't retain root for local definitions 2375 for (key in resolvedTo.obj) { 2376 var abs = this.retainRoot(resolvedTo.obj[key], item.root); 2377 } 2378 } 2379 spec.definitions[resolvedTo.name] = resolvedTo.obj; 2380 item.obj.$ref = '#/definitions/' + resolvedTo.name; 2381 } else if (item.resolveAs === 'inline') { 2382 var targetObj = item.obj; 2383 targetObj['x-resolved-from'] = [ item.key ]; 2384 delete targetObj.$ref; 2385 2386 for (key in resolvedTo.obj) { 2387 var abs = resolvedTo.obj[key]; 2388 2389 if (localResolve !== true) { 2390 // don't retain root for local definitions 2391 abs = this.retainRoot(resolvedTo.obj[key], item.root); 2392 } 2393 targetObj[key] = abs; 2394 } 2395 } 2396 } 2397 } 2398 var existingUnresolved = this.countUnresolvedRefs(spec); 2399 2400 if(existingUnresolved === 0 || this.iteration > 5) { 2401 this.resolveAllOf(spec.definitions); 2402 callback.call(this.scope, spec, unresolvedRefs); 2403 } 2404 else { 2405 this.iteration += 1; 2406 this.resolve(spec, root, callback, this.scope); 2407 } 2408 }; 2409 2410 Resolver.prototype.countUnresolvedRefs = function(spec) { 2411 var i; 2412 var refs = this.getRefs(spec); 2413 var keys = []; 2414 var unresolvedKeys = []; 2415 for(i in refs) { 2416 if(i.indexOf('#') === 0) { 2417 keys.push(i.substring(1)); 2418 } 2419 else { 2420 unresolvedKeys.push(i); 2421 } 2422 } 2423 2424 // verify possible keys 2425 for (i = 0; i < keys.length; i++) { 2426 var part = keys[i]; 2427 var parts = part.split('/'); 2428 var obj = spec; 2429 2430 for (var k = 0; k < parts.length; k++) { 2431 var key = parts[k]; 2432 if(key !== '') { 2433 obj = obj[key]; 2434 if(typeof obj === 'undefined') { 2435 unresolvedKeys.push(part); 2436 break; 2437 } 2438 } 2439 } 2440 } 2441 return unresolvedKeys.length; 2442 }; 2443 2444 Resolver.prototype.getRefs = function(spec, obj) { 2445 obj = obj || spec; 2446 var output = {}; 2447 for(var key in obj) { 2448 if (!obj.hasOwnProperty(key)) { 2449 continue; 2450 } 2451 var item = obj[key]; 2452 if(key === '$ref' && typeof item === 'string') { 2453 output[item] = null; 2454 } 2455 else if(_.isObject(item)) { 2456 var o = this.getRefs(item); 2457 for(var k in o) { 2458 output[k] = null; 2459 } 2460 } 2461 } 2462 return output; 2463 }; 2464 2465 Resolver.prototype.retainRoot = function(obj, root) { 2466 // walk object and look for relative $refs 2467 for(var key in obj) { 2468 var item = obj[key]; 2469 if(key === '$ref' && typeof item === 'string') { 2470 // stop and inspect 2471 if(item.indexOf('http://') !== 0 && item.indexOf('https://') !== 0) { 2472 if(item.indexOf('#') !== 0) { 2473 item = '#' + item; 2474 } 2475 item = (root || '') + item; 2476 obj[key] = item; 2477 } 2478 } 2479 else if(_.isObject(item)) { 2480 this.retainRoot(item, root); 2481 } 2482 } 2483 return obj; 2484 }; 2485 2486 /** 2487 * immediately in-lines local refs, queues remote refs 2488 * for inline resolution 2489 */ 2490 Resolver.prototype.resolveInline = function (root, spec, property, resolutionTable, unresolvedRefs, location) { 2491 var key = property.$ref, ref = property.$ref, i, p, p2, rs; 2492 var rootTrimmed = false; 2493 if (ref) { 2494 if(ref.indexOf('../') === 0) { 2495 // reset root 2496 p = ref.split('../'); 2497 p2 = root.split('/'); 2498 ref = ''; 2499 for(i = 0; i < p.length; i++) { 2500 if(p[i] === '') { 2501 p2 = p2.slice(0, p2.length-1); 2502 } 2503 else { 2504 ref += p[i]; 2505 } 2506 } 2507 root = ''; 2508 for(i = 0; i < p2.length - 1; i++) { 2509 if(i > 0) { root += '/'; } 2510 root += p2[i]; 2511 } 2512 rootTrimmed = true; 2513 } 2514 if(ref.indexOf('#') >= 0) { 2515 if(ref.indexOf('/') === 0) { 2516 rs = ref.split('#'); 2517 p = root.split('//'); 2518 p2 = p[1].split('/'); 2519 root = p[0] + '//' + p2[0] + rs[0]; 2520 location = rs[1]; 2521 } 2522 else { 2523 rs = ref.split('#'); 2524 if(rs[0] !== '') { 2525 p2 = root.split('/'); 2526 p2 = p2.slice(0, p2.length - 1); 2527 if(!rootTrimmed) { 2528 root = ''; 2529 for (var k = 0; k < p2.length; k++) { 2530 if(k > 0) { root += '/'; } 2531 root += p2[k]; 2532 } 2533 } 2534 root += '/' + ref.split('#')[0]; 2535 } 2536 location = rs[1]; 2537 } 2538 } 2539 if (ref.indexOf('http') === 0) { 2540 if(ref.indexOf('#') >= 0) { 2541 root = ref.split('#')[0]; 2542 location = ref.split('#')[1]; 2543 } 2544 else { 2545 root = ref; 2546 location = ''; 2547 } 2548 resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location}); 2549 } else if (ref.indexOf('#') === 0) { 2550 location = ref.split('#')[1]; 2551 resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location}); 2552 } 2553 else { 2554 resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location}); 2555 } 2556 } 2557 else if (property.type === 'array') { 2558 this.resolveTo(root, property.items, resolutionTable, location); 2559 } 2560 }; 2561 2562 Resolver.prototype.resolveTo = function (root, property, resolutionTable, location) { 2563 var sp, i; 2564 var ref = property.$ref; 2565 var lroot = root; 2566 if (typeof ref !== 'undefined') { 2567 if(ref.indexOf('#') >= 0) { 2568 var parts = ref.split('#'); 2569 2570 // #/definitions/foo 2571 // foo.json#/bar 2572 if(parts[0] && ref.indexOf('/') === 0) { 2573 2574 } 2575 else if(parts[0] && parts[0].indexOf('http') === 0) { 2576 lroot = parts[0]; 2577 ref = parts[1]; 2578 } 2579 else if(parts[0] && parts[0].length > 0) { 2580 // relative file 2581 sp = root.split('/'); 2582 lroot = ''; 2583 for(i = 0; i < sp.length - 1; i++) { 2584 lroot += sp[i] + '/'; 2585 } 2586 lroot += parts[0]; 2587 } 2588 else { 2589 2590 } 2591 2592 location = parts[1]; 2593 } 2594 else if (ref.indexOf('http://') === 0 || ref.indexOf('https://') === 0) { 2595 lroot = ref; 2596 location = ''; 2597 } 2598 else { 2599 // relative file 2600 sp = root.split('/'); 2601 lroot = ''; 2602 for(i = 0; i < sp.length - 1; i++) { 2603 lroot += sp[i] + '/'; 2604 } 2605 lroot += ref; 2606 location = ''; 2607 } 2608 resolutionTable.push({ 2609 obj: property, resolveAs: 'ref', root: lroot, key: ref, location: location 2610 }); 2611 } else if (property.type === 'array') { 2612 var items = property.items; 2613 this.resolveTo(root, items, resolutionTable, location); 2614 } else { 2615 if(property && property.properties) { 2616 var name = this.uniqueName('inline_model'); 2617 this.spec.definitions[name] = _.cloneDeep(property); 2618 property['$ref'] = '#/definitions/' + name; 2619 delete property.type; 2620 delete property.properties; 2621 } 2622 } 2623 }; 2624 2625 Resolver.prototype.uniqueName = function(base) { 2626 var name = base; 2627 var count = 0; 2628 while(true) { 2629 if(!_.isObject(this.spec.definitions[name])) { 2630 return name; 2631 } 2632 name = base + '_' + count; 2633 count++; 2634 } 2635 }; 2636 2637 Resolver.prototype.resolveAllOf = function(spec, obj, depth) { 2638 depth = depth || 0; 2639 obj = obj || spec; 2640 var name; 2641 for(var key in obj) { 2642 if (!obj.hasOwnProperty(key)) { 2643 continue; 2644 } 2645 var item = obj[key]; 2646 if(item === null) { 2647 throw new TypeError('Swagger 2.0 does not support null types (' + obj + '). See https://github.com/swagger-api/swagger-spec/issues/229.'); 2648 } 2649 if(typeof item === 'object') { 2650 this.resolveAllOf(spec, item, depth + 1); 2651 } 2652 if(item && typeof item.allOf !== 'undefined') { 2653 var allOf = item.allOf; 2654 if(_.isArray(allOf)) { 2655 var output = _.cloneDeep(item); 2656 delete output.allOf; 2657 2658 output['x-composed'] = true; 2659 if (typeof item['x-resolved-from'] !== 'undefined') { 2660 output['x-resolved-from'] = item['x-resolved-from']; 2661 } 2662 2663 for(var i = 0; i < allOf.length; i++) { 2664 var component = allOf[i]; 2665 var source = 'self'; 2666 if(typeof component['x-resolved-from'] !== 'undefined') { 2667 source = component['x-resolved-from'][0]; 2668 } 2669 2670 for(var part in component) { 2671 if(!output.hasOwnProperty(part)) { 2672 output[part] = _.cloneDeep(component[part]); 2673 if(part === 'properties') { 2674 for(name in output[part]) { 2675 output[part][name]['x-resolved-from'] = source; 2676 } 2677 } 2678 } 2679 else { 2680 if(part === 'properties') { 2681 var properties = component[part]; 2682 for(name in properties) { 2683 output.properties[name] = _.cloneDeep(properties[name]); 2684 var resolvedFrom = properties[name]['x-resolved-from']; 2685 if (typeof resolvedFrom === 'undefined' || resolvedFrom === 'self') { 2686 resolvedFrom = source; 2687 } 2688 output.properties[name]['x-resolved-from'] = resolvedFrom; 2689 } 2690 } 2691 else if(part === 'required') { 2692 // merge & dedup the required array 2693 var a = output.required.concat(component[part]); 2694 for(var k = 0; k < a.length; ++k) { 2695 for(var j = k + 1; j < a.length; ++j) { 2696 if(a[k] === a[j]) { a.splice(j--, 1); } 2697 } 2698 } 2699 output.required = a; 2700 } 2701 else if(part === 'x-resolved-from') { 2702 output['x-resolved-from'].push(source); 2703 } 2704 else { 2705 // TODO: need to merge this property 2706 // console.log('what to do with ' + part) 2707 } 2708 } 2709 } 2710 } 2711 obj[key] = output; 2712 } 2713 } 2714 if(_.isObject(item)) { 2715 this.resolveAllOf(spec, item, depth + 1); 2716 } 2717 } 2718 }; 2719 2720 },{"./http":5,"lodash-compat/lang/cloneDeep":142,"lodash-compat/lang/isArray":144,"lodash-compat/lang/isObject":148}],7:[function(require,module,exports){ 2721 'use strict'; 2722 2723 var Helpers = require('./helpers'); 2724 2725 var _ = { 2726 isPlainObject: require('lodash-compat/lang/isPlainObject'), 2727 isUndefined: require('lodash-compat/lang/isUndefined'), 2728 isArray: require('lodash-compat/lang/isArray'), 2729 isObject: require('lodash-compat/lang/isObject'), 2730 isEmpty: require('lodash-compat/lang/isEmpty'), 2731 map: require('lodash-compat/collection/map'), 2732 indexOf: require('lodash-compat/array/indexOf'), 2733 cloneDeep: require('lodash-compat/lang/cloneDeep'), 2734 keys: require('lodash-compat/object/keys'), 2735 forEach: require('lodash-compat/collection/forEach') 2736 }; 2737 2738 module.exports.optionHtml = optionHtml; 2739 module.exports.typeFromJsonSchema = typeFromJsonSchema; 2740 module.exports.getStringSignature = getStringSignature; 2741 module.exports.schemaToHTML = schemaToHTML; 2742 module.exports.schemaToJSON = schemaToJSON; 2743 2744 function optionHtml(label, value) { 2745 return '<tr><td class="optionName">' + label + ':</td><td>' + value + '</td></tr>'; 2746 } 2747 2748 function typeFromJsonSchema(type, format) { 2749 var str; 2750 2751 if (type === 'integer' && format === 'int32') { 2752 str = 'integer'; 2753 } else if (type === 'integer' && format === 'int64') { 2754 str = 'long'; 2755 } else if (type === 'integer' && typeof format === 'undefined') { 2756 str = 'long'; 2757 } else if (type === 'string' && format === 'date-time') { 2758 str = 'date-time'; 2759 } else if (type === 'string' && format === 'date') { 2760 str = 'date'; 2761 } else if (type === 'number' && format === 'float') { 2762 str = 'float'; 2763 } else if (type === 'number' && format === 'double') { 2764 str = 'double'; 2765 } else if (type === 'number' && typeof format === 'undefined') { 2766 str = 'double'; 2767 } else if (type === 'boolean') { 2768 str = 'boolean'; 2769 } else if (type === 'string') { 2770 str = 'string'; 2771 } 2772 2773 return str; 2774 } 2775 2776 function getStringSignature(obj, baseComponent) { 2777 var str = ''; 2778 2779 if (typeof obj.$ref !== 'undefined') { 2780 str += Helpers.simpleRef(obj.$ref); 2781 } else if (typeof obj.type === 'undefined') { 2782 str += 'object'; 2783 } else if (obj.type === 'array') { 2784 if (baseComponent) { 2785 str += getStringSignature((obj.items || obj.$ref || {})); 2786 } else { 2787 str += 'Array['; 2788 str += getStringSignature((obj.items || obj.$ref || {})); 2789 str += ']'; 2790 } 2791 } else if (obj.type === 'integer' && obj.format === 'int32') { 2792 str += 'integer'; 2793 } else if (obj.type === 'integer' && obj.format === 'int64') { 2794 str += 'long'; 2795 } else if (obj.type === 'integer' && typeof obj.format === 'undefined') { 2796 str += 'long'; 2797 } else if (obj.type === 'string' && obj.format === 'date-time') { 2798 str += 'date-time'; 2799 } else if (obj.type === 'string' && obj.format === 'date') { 2800 str += 'date'; 2801 } else if (obj.type === 'string' && typeof obj.format === 'undefined') { 2802 str += 'string'; 2803 } else if (obj.type === 'number' && obj.format === 'float') { 2804 str += 'float'; 2805 } else if (obj.type === 'number' && obj.format === 'double') { 2806 str += 'double'; 2807 } else if (obj.type === 'number' && typeof obj.format === 'undefined') { 2808 str += 'double'; 2809 } else if (obj.type === 'boolean') { 2810 str += 'boolean'; 2811 } else if (obj.$ref) { 2812 str += Helpers.simpleRef(obj.$ref); 2813 } else { 2814 str += obj.type; 2815 } 2816 2817 return str; 2818 } 2819 2820 function schemaToJSON(schema, models, modelsToIgnore, modelPropertyMacro) { 2821 // Resolve the schema (Handle nested schemas) 2822 schema = Helpers.resolveSchema(schema); 2823 2824 if(typeof modelPropertyMacro !== 'function') { 2825 modelPropertyMacro = function(prop){ 2826 return (prop || {}).default; 2827 }; 2828 } 2829 2830 modelsToIgnore= modelsToIgnore || {}; 2831 2832 var type = schema.type || 'object'; 2833 var format = schema.format; 2834 var model; 2835 var output; 2836 2837 if (!_.isUndefined(schema.example)) { 2838 output = schema.example; 2839 } else if (_.isUndefined(schema.items) && _.isArray(schema.enum)) { 2840 output = schema.enum[0]; 2841 } 2842 2843 if (_.isUndefined(output)) { 2844 if (schema.$ref) { 2845 model = models[Helpers.simpleRef(schema.$ref)]; 2846 2847 if (!_.isUndefined(model)) { 2848 if (_.isUndefined(modelsToIgnore[model.name])) { 2849 modelsToIgnore[model.name] = model; 2850 output = schemaToJSON(model.definition, models, modelsToIgnore, modelPropertyMacro); 2851 delete modelsToIgnore[model.name]; 2852 } else { 2853 if (model.type === 'array') { 2854 output = []; 2855 } else { 2856 output = {}; 2857 } 2858 } 2859 } 2860 } else if (!_.isUndefined(schema.default)) { 2861 output = schema.default; 2862 } else if (type === 'string') { 2863 if (format === 'date-time') { 2864 output = new Date().toISOString(); 2865 } else if (format === 'date') { 2866 output = new Date().toISOString().split('T')[0]; 2867 } else { 2868 output = 'string'; 2869 } 2870 } else if (type === 'integer') { 2871 output = 0; 2872 } else if (type === 'number') { 2873 output = 0.0; 2874 } else if (type === 'boolean') { 2875 output = true; 2876 } else if (type === 'object') { 2877 output = {}; 2878 2879 _.forEach(schema.properties, function (property, name) { 2880 var cProperty = _.cloneDeep(property); 2881 2882 // Allow macro to set the default value 2883 cProperty.default = modelPropertyMacro(property); 2884 2885 output[name] = schemaToJSON(cProperty, models, modelsToIgnore, modelPropertyMacro); 2886 }); 2887 } else if (type === 'array') { 2888 output = []; 2889 2890 if (_.isArray(schema.items)) { 2891 _.forEach(schema.items, function (item) { 2892 output.push(schemaToJSON(item, models, modelsToIgnore, modelPropertyMacro)); 2893 }); 2894 } else if (_.isPlainObject(schema.items)) { 2895 output.push(schemaToJSON(schema.items, models, modelsToIgnore, modelPropertyMacro)); 2896 } else if (_.isUndefined(schema.items)) { 2897 output.push({}); 2898 } else { 2899 Helpers.log('Array type\'s \'items\' property is not an array or an object, cannot process'); 2900 } 2901 } 2902 } 2903 2904 return output; 2905 } 2906 2907 function schemaToHTML(name, schema, models, modelPropertyMacro) { 2908 2909 var strongOpen = '<span class="strong">'; 2910 var strongClose = '</span>'; 2911 2912 // Allow for ignoring the 'name' argument.... shifting the rest 2913 if(_.isObject(arguments[0])) { 2914 name = void 0; 2915 schema = arguments[0]; 2916 models = arguments[1]; 2917 modelPropertyMacro = arguments[2]; 2918 } 2919 2920 models = models || {}; 2921 2922 // Resolve the schema (Handle nested schemas) 2923 schema = Helpers.resolveSchema(schema); 2924 2925 // Return for empty object 2926 if(_.isEmpty(schema)) { 2927 return strongOpen + 'Empty' + strongClose; 2928 } 2929 2930 // Dereference $ref from 'models' 2931 if(typeof schema.$ref === 'string') { 2932 name = Helpers.simpleRef(schema.$ref); 2933 schema = models[name]; 2934 if(typeof schema === 'undefined') 2935 { 2936 return strongOpen + name + ' is not defined!' + strongClose; 2937 } 2938 } 2939 2940 if(typeof name !== 'string') { 2941 name = schema.title || 'Inline Model'; 2942 } 2943 2944 // If we are a Model object... adjust accordingly 2945 if(schema.definition) { 2946 schema = schema.definition; 2947 } 2948 2949 if(typeof modelPropertyMacro !== 'function') { 2950 modelPropertyMacro = function(prop){ 2951 return (prop || {}).default; 2952 }; 2953 } 2954 2955 var references = {}; 2956 var seenModels = []; 2957 var inlineModels = 0; 2958 2959 2960 2961 // Generate current HTML 2962 var html = processModel(schema, name); 2963 2964 // Generate references HTML 2965 while (_.keys(references).length > 0) { 2966 /* jshint ignore:start */ 2967 _.forEach(references, function (schema, name) { 2968 var seenModel = _.indexOf(seenModels, name) > -1; 2969 2970 delete references[name]; 2971 2972 if (!seenModel) { 2973 seenModels.push(name); 2974 2975 html += '<br />' + processModel(schema, name); 2976 } 2977 }); 2978 /* jshint ignore:end */ 2979 } 2980 2981 return html; 2982 2983 ///////////////////////////////// 2984 2985 function addReference(schema, name, skipRef) { 2986 var modelName = name; 2987 var model; 2988 2989 if (schema.$ref) { 2990 modelName = schema.title || Helpers.simpleRef(schema.$ref); 2991 model = models[modelName]; 2992 } else if (_.isUndefined(name)) { 2993 modelName = schema.title || 'Inline Model ' + (++inlineModels); 2994 model = {definition: schema}; 2995 } 2996 2997 if (skipRef !== true) { 2998 references[modelName] = _.isUndefined(model) ? {} : model.definition; 2999 } 3000 3001 return modelName; 3002 } 3003 3004 function primitiveToHTML(schema) { 3005 var html = '<span class="propType">'; 3006 var type = schema.type || 'object'; 3007 3008 if (schema.$ref) { 3009 html += addReference(schema, Helpers.simpleRef(schema.$ref)); 3010 } else if (type === 'object') { 3011 if (!_.isUndefined(schema.properties)) { 3012 html += addReference(schema); 3013 } else { 3014 html += 'object'; 3015 } 3016 } else if (type === 'array') { 3017 html += 'Array['; 3018 3019 if (_.isArray(schema.items)) { 3020 html += _.map(schema.items, addReference).join(','); 3021 } else if (_.isPlainObject(schema.items)) { 3022 if (_.isUndefined(schema.items.$ref)) { 3023 if (!_.isUndefined(schema.items.type) && _.indexOf(['array', 'object'], schema.items.type) === -1) { 3024 html += schema.items.type; 3025 } else { 3026 html += addReference(schema.items); 3027 } 3028 } else { 3029 html += addReference(schema.items, Helpers.simpleRef(schema.items.$ref)); 3030 } 3031 } else { 3032 Helpers.log('Array type\'s \'items\' schema is not an array or an object, cannot process'); 3033 html += 'object'; 3034 } 3035 3036 html += ']'; 3037 } else { 3038 html += schema.type; 3039 } 3040 3041 html += '</span>'; 3042 3043 return html; 3044 } 3045 3046 function primitiveToOptionsHTML(schema, html) { 3047 var options = ''; 3048 var type = schema.type || 'object'; 3049 var isArray = type === 'array'; 3050 3051 if (isArray) { 3052 if (_.isPlainObject(schema.items) && !_.isUndefined(schema.items.type)) { 3053 type = schema.items.type; 3054 } else { 3055 type = 'object'; 3056 } 3057 } 3058 3059 if (!_.isUndefined(schema.default)) { 3060 options += optionHtml('Default', schema.default); 3061 } 3062 3063 switch (type) { 3064 case 'string': 3065 if (schema.minLength) { 3066 options += optionHtml('Min. Length', schema.minLength); 3067 } 3068 3069 if (schema.maxLength) { 3070 options += optionHtml('Max. Length', schema.maxLength); 3071 } 3072 3073 if (schema.pattern) { 3074 options += optionHtml('Reg. Exp.', schema.pattern); 3075 } 3076 break; 3077 case 'integer': 3078 case 'number': 3079 if (schema.minimum) { 3080 options += optionHtml('Min. Value', schema.minimum); 3081 } 3082 3083 if (schema.exclusiveMinimum) { 3084 options += optionHtml('Exclusive Min.', 'true'); 3085 } 3086 3087 if (schema.maximum) { 3088 options += optionHtml('Max. Value', schema.maximum); 3089 } 3090 3091 if (schema.exclusiveMaximum) { 3092 options += optionHtml('Exclusive Max.', 'true'); 3093 } 3094 3095 if (schema.multipleOf) { 3096 options += optionHtml('Multiple Of', schema.multipleOf); 3097 } 3098 3099 break; 3100 } 3101 3102 if (isArray) { 3103 if (schema.minItems) { 3104 options += optionHtml('Min. Items', schema.minItems); 3105 } 3106 3107 if (schema.maxItems) { 3108 options += optionHtml('Max. Items', schema.maxItems); 3109 } 3110 3111 if (schema.uniqueItems) { 3112 options += optionHtml('Unique Items', 'true'); 3113 } 3114 3115 if (schema.collectionFormat) { 3116 options += optionHtml('Coll. Format', schema.collectionFormat); 3117 } 3118 } 3119 3120 if (_.isUndefined(schema.items)) { 3121 if (_.isArray(schema.enum)) { 3122 var enumString; 3123 3124 if (type === 'number' || type === 'integer') { 3125 enumString = schema.enum.join(', '); 3126 } else { 3127 enumString = '"' + schema.enum.join('", "') + '"'; 3128 } 3129 3130 options += optionHtml('Enum', enumString); 3131 } 3132 } 3133 3134 if (options.length > 0) { 3135 html = '<span class="propWrap">' + html + '<table class="optionsWrapper"><tr><th colspan="2">' + type + '</th></tr>' + options + '</table></span>'; 3136 } 3137 3138 return html; 3139 } 3140 3141 function processModel(schema, name) { 3142 var type = schema.type || 'object'; 3143 var isArray = schema.type === 'array'; 3144 var html = strongOpen + name + ' ' + (isArray ? '[' : '{') + strongClose; 3145 3146 if (name) { 3147 seenModels.push(name); 3148 } 3149 3150 if (isArray) { 3151 if (_.isArray(schema.items)) { 3152 html += '<div>' + _.map(schema.items, function (item) { 3153 var type = item.type || 'object'; 3154 3155 if (_.isUndefined(item.$ref)) { 3156 if (_.indexOf(['array', 'object'], type) > -1) { 3157 if (type === 'object' && _.isUndefined(item.properties)) { 3158 return 'object'; 3159 } else { 3160 return addReference(item); 3161 } 3162 } else { 3163 return primitiveToOptionsHTML(item, type); 3164 } 3165 } else { 3166 return addReference(item, Helpers.simpleRef(item.$ref)); 3167 } 3168 }).join(',</div><div>'); 3169 } else if (_.isPlainObject(schema.items)) { 3170 if (_.isUndefined(schema.items.$ref)) { 3171 if (_.indexOf(['array', 'object'], schema.items.type || 'object') > -1) { 3172 if ((_.isUndefined(schema.items.type) || schema.items.type === 'object') && _.isUndefined(schema.items.properties)) { 3173 html += '<div>object</div>'; 3174 } else { 3175 html += '<div>' + addReference(schema.items) + '</div>'; 3176 } 3177 } else { 3178 html += '<div>' + primitiveToOptionsHTML(schema.items, schema.items.type) + '</div>'; 3179 } 3180 } else { 3181 html += '<div>' + addReference(schema.items, Helpers.simpleRef(schema.items.$ref)) + '</div>'; 3182 } 3183 } else { 3184 Helpers.log('Array type\'s \'items\' property is not an array or an object, cannot process'); 3185 html += '<div>object</div>'; 3186 } 3187 } else { 3188 if (schema.$ref) { 3189 html += '<div>' + addReference(schema, name) + '</div>'; 3190 } else if (type === 'object') { 3191 if (_.isPlainObject(schema.properties)) { 3192 var contents = _.map(schema.properties, function (property, name) { 3193 var propertyIsRequired = (_.indexOf(schema.required, name) >= 0); 3194 var cProperty = _.cloneDeep(property); 3195 3196 var requiredClass = propertyIsRequired ? 'required' : ''; 3197 var html = '<div' + (property.readOnly ? ' class="readOnly"' : '') + '><span class="propName ' + requiredClass + '">' + name + '</span> ('; 3198 var model; 3199 var propDescription; 3200 3201 // Allow macro to set the default value 3202 cProperty.default = modelPropertyMacro(cProperty); 3203 3204 // Resolve the schema (Handle nested schemas) 3205 cProperty = Helpers.resolveSchema(cProperty); 3206 3207 propDescription = property.description || cProperty.description; 3208 3209 // We need to handle property references to primitives (Issue 339) 3210 if (!_.isUndefined(cProperty.$ref)) { 3211 model = models[Helpers.simpleRef(cProperty.$ref)]; 3212 3213 if (!_.isUndefined(model) && _.indexOf([undefined, 'array', 'object'], model.definition.type) === -1) { 3214 // Use referenced schema 3215 cProperty = Helpers.resolveSchema(model.definition); 3216 } 3217 } 3218 3219 html += primitiveToHTML(cProperty); 3220 3221 if(!propertyIsRequired) { 3222 html += ', <span class="propOptKey">optional</span>'; 3223 } 3224 3225 if(property.readOnly) { 3226 html += ', <span class="propReadOnly">read only</span>'; 3227 } 3228 3229 html += ')'; 3230 3231 if (!_.isUndefined(propDescription)) { 3232 html += ': ' + '<span class="propDesc">' + propDescription + '</span>'; 3233 } 3234 3235 if (cProperty.enum) { 3236 html += ' = <span class="propVals">[\'' + cProperty.enum.join('\', \'') + '\']</span>'; 3237 } 3238 3239 return primitiveToOptionsHTML(cProperty, html); 3240 }).join(',</div>'); 3241 } 3242 3243 if (contents) { 3244 html += contents + '</div>'; 3245 } 3246 } else { 3247 html += '<div>' + primitiveToOptionsHTML(schema, type) + '</div>'; 3248 } 3249 } 3250 3251 return html + strongOpen + (isArray ? ']' : '}') + strongClose; 3252 } 3253 } 3254 3255 },{"./helpers":4,"lodash-compat/array/indexOf":53,"lodash-compat/collection/forEach":58,"lodash-compat/collection/map":60,"lodash-compat/lang/cloneDeep":142,"lodash-compat/lang/isArray":144,"lodash-compat/lang/isEmpty":145,"lodash-compat/lang/isObject":148,"lodash-compat/lang/isPlainObject":149,"lodash-compat/lang/isUndefined":152,"lodash-compat/object/keys":153}],8:[function(require,module,exports){ 3256 'use strict'; 3257 3258 var SwaggerHttp = require('./http'); 3259 var _ = { 3260 isObject: require('lodash-compat/lang/isObject') 3261 }; 3262 3263 var SwaggerSpecConverter = module.exports = function () { 3264 this.errors = []; 3265 this.warnings = []; 3266 this.modelMap = {}; 3267 }; 3268 3269 SwaggerSpecConverter.prototype.setDocumentationLocation = function (location) { 3270 this.docLocation = location; 3271 }; 3272 3273 /** 3274 * converts a resource listing OR api declaration 3275 **/ 3276 SwaggerSpecConverter.prototype.convert = function (obj, clientAuthorizations, opts, callback) { 3277 // not a valid spec 3278 if(!obj || !Array.isArray(obj.apis)) { 3279 return this.finish(callback, null); 3280 } 3281 this.clientAuthorizations = clientAuthorizations; 3282 3283 // create a new swagger object to return 3284 var swagger = { swagger: '2.0' }; 3285 3286 swagger.originalVersion = obj.swaggerVersion; 3287 3288 // add the info 3289 this.apiInfo(obj, swagger); 3290 3291 // add security definitions 3292 this.securityDefinitions(obj, swagger); 3293 3294 // take basePath into account 3295 if (obj.basePath) { 3296 this.setDocumentationLocation(obj.basePath); 3297 } 3298 3299 // see if this is a single-file swagger definition 3300 var isSingleFileSwagger = false; 3301 var i; 3302 for(i = 0; i < obj.apis.length; i++) { 3303 var api = obj.apis[i]; 3304 if(Array.isArray(api.operations)) { 3305 isSingleFileSwagger = true; 3306 } 3307 } 3308 if(isSingleFileSwagger) { 3309 this.declaration(obj, swagger); 3310 this.finish(callback, swagger); 3311 } 3312 else { 3313 this.resourceListing(obj, swagger, opts, callback); 3314 } 3315 }; 3316 3317 SwaggerSpecConverter.prototype.declaration = function(obj, swagger) { 3318 var name, i, p, pos; 3319 if(!obj.apis) { 3320 return; 3321 } 3322 3323 if (obj.basePath.indexOf('http://') === 0) { 3324 p = obj.basePath.substring('http://'.length); 3325 pos = p.indexOf('/'); 3326 if (pos > 0) { 3327 swagger.host = p.substring(0, pos); 3328 swagger.basePath = p.substring(pos); 3329 } 3330 else { 3331 swagger.host = p; 3332 swagger.basePath = '/'; 3333 } 3334 } else if (obj.basePath.indexOf('https://') === 0) { 3335 p = obj.basePath.substring('https://'.length); 3336 pos = p.indexOf('/'); 3337 if (pos > 0) { 3338 swagger.host = p.substring(0, pos); 3339 swagger.basePath = p.substring(pos); 3340 } 3341 else { 3342 swagger.host = p; 3343 swagger.basePath = '/'; 3344 } 3345 } else { 3346 swagger.basePath = obj.basePath; 3347 } 3348 3349 var resourceLevelAuth; 3350 if(obj.authorizations) { 3351 resourceLevelAuth = obj.authorizations; 3352 } 3353 if(obj.consumes) { 3354 swagger.consumes = obj.consumes; 3355 } 3356 if(obj.produces) { 3357 swagger.produces = obj.produces; 3358 } 3359 3360 // build a mapping of id to name for 1.0 model resolutions 3361 if(_.isObject(obj)) { 3362 for(name in obj.models) { 3363 var existingModel = obj.models[name]; 3364 var key = (existingModel.id || name); 3365 this.modelMap[key] = name; 3366 } 3367 } 3368 3369 for(i = 0; i < obj.apis.length; i++) { 3370 var api = obj.apis[i]; 3371 var path = api.path; 3372 var operations = api.operations; 3373 this.operations(path, obj.resourcePath, operations, resourceLevelAuth, swagger); 3374 } 3375 3376 var models = obj.models || {}; 3377 this.models(models, swagger); 3378 }; 3379 3380 SwaggerSpecConverter.prototype.models = function(obj, swagger) { 3381 if(!_.isObject(obj)) { 3382 return; 3383 } 3384 var name; 3385 3386 swagger.definitions = swagger.definitions || {}; 3387 for(name in obj) { 3388 var existingModel = obj[name]; 3389 var _enum = []; 3390 var schema = { properties: {}}; 3391 var propertyName; 3392 for(propertyName in existingModel.properties) { 3393 var existingProperty = existingModel.properties[propertyName]; 3394 var property = {}; 3395 this.dataType(existingProperty, property); 3396 if(existingProperty.description) { 3397 property.description = existingProperty.description; 3398 } 3399 if(existingProperty['enum']) { 3400 property['enum'] = existingProperty['enum']; 3401 } 3402 if(typeof existingProperty.required === 'boolean' && existingProperty.required === true) { 3403 _enum.push(propertyName); 3404 } 3405 if(typeof existingProperty.required === 'string' && existingProperty.required === 'true') { 3406 _enum.push(propertyName); 3407 } 3408 schema.properties[propertyName] = property; 3409 } 3410 if(_enum.length > 0) { 3411 schema['enum'] = _enum; 3412 } 3413 3414 schema.required = existingModel.required; 3415 swagger.definitions[name] = schema; 3416 } 3417 }; 3418 3419 SwaggerSpecConverter.prototype.extractTag = function(resourcePath) { 3420 var pathString = resourcePath || 'default'; 3421 if(pathString.indexOf('http:') === 0 || pathString.indexOf('https:') === 0) { 3422 pathString = pathString.split(['/']); 3423 pathString = pathString[pathString.length -1].substring(); 3424 } 3425 if(pathString.endsWith('.json')) { 3426 pathString = pathString.substring(0, pathString.length - '.json'.length); 3427 } 3428 return pathString.replace('/',''); 3429 }; 3430 3431 SwaggerSpecConverter.prototype.operations = function(path, resourcePath, obj, resourceLevelAuth, swagger) { 3432 if(!Array.isArray(obj)) { 3433 return; 3434 } 3435 var i; 3436 3437 if(!swagger.paths) { 3438 swagger.paths = {}; 3439 } 3440 3441 var pathObj = swagger.paths[path] || {}; 3442 var tag = this.extractTag(resourcePath); 3443 swagger.tags = swagger.tags || []; 3444 var matched = false; 3445 for(i = 0; i < swagger.tags.length; i++) { 3446 var tagObject = swagger.tags[i]; 3447 if(tagObject.name === tag) { 3448 matched = true; 3449 } 3450 } 3451 if(!matched) { 3452 swagger.tags.push({name: tag}); 3453 } 3454 3455 for(i = 0; i < obj.length; i++) { 3456 var existingOperation = obj[i]; 3457 var method = (existingOperation.method || existingOperation.httpMethod).toLowerCase(); 3458 var operation = {tags: [tag]}; 3459 var existingAuthorizations = existingOperation.authorizations; 3460 3461 if(existingAuthorizations && Object.keys(existingAuthorizations).length === 0) { 3462 existingAuthorizations = resourceLevelAuth; 3463 } 3464 3465 if(typeof existingAuthorizations !== 'undefined') { 3466 var scopesObject; 3467 for(var key in existingAuthorizations) { 3468 operation.security = operation.security || []; 3469 var scopes = existingAuthorizations[key]; 3470 if(scopes) { 3471 var securityScopes = []; 3472 for(var j in scopes) { 3473 securityScopes.push(scopes[j].scope); 3474 } 3475 scopesObject = {}; 3476 scopesObject[key] = securityScopes; 3477 operation.security.push(scopesObject); 3478 } 3479 else { 3480 scopesObject = {}; 3481 scopesObject[key] = []; 3482 operation.security.push(scopesObject); 3483 } 3484 } 3485 } 3486 3487 if(existingOperation.consumes) { 3488 operation.consumes = existingOperation.consumes; 3489 } 3490 else if(swagger.consumes) { 3491 operation.consumes = swagger.consumes; 3492 } 3493 if(existingOperation.produces) { 3494 operation.produces = existingOperation.produces; 3495 } 3496 else if(swagger.produces) { 3497 operation.produces = swagger.produces; 3498 } 3499 if(existingOperation.summary) { 3500 operation.summary = existingOperation.summary; 3501 } 3502 if(existingOperation.notes) { 3503 operation.description = existingOperation.notes; 3504 } 3505 if(existingOperation.nickname) { 3506 operation.operationId = existingOperation.nickname; 3507 } 3508 if(existingOperation.deprecated) { 3509 operation.deprecated = existingOperation.deprecated; 3510 } 3511 3512 this.authorizations(existingAuthorizations, swagger); 3513 this.parameters(operation, existingOperation.parameters, swagger); 3514 this.responseMessages(operation, existingOperation, swagger); 3515 3516 pathObj[method] = operation; 3517 } 3518 3519 swagger.paths[path] = pathObj; 3520 }; 3521 3522 SwaggerSpecConverter.prototype.responseMessages = function(operation, existingOperation) { 3523 if(!_.isObject(existingOperation)) { 3524 return; 3525 } 3526 // build default response from the operation (1.x) 3527 var defaultResponse = {}; 3528 this.dataType(existingOperation, defaultResponse); 3529 // TODO: look into the real problem of rendering responses in swagger-ui 3530 // ....should reponseType have an implicit schema? 3531 if(!defaultResponse.schema && defaultResponse.type) { 3532 defaultResponse = {schema: defaultResponse}; 3533 } 3534 3535 operation.responses = operation.responses || {}; 3536 3537 // grab from responseMessages (1.2) 3538 var has200 = false; 3539 if(Array.isArray(existingOperation.responseMessages)) { 3540 var i; 3541 var existingResponses = existingOperation.responseMessages; 3542 for(i = 0; i < existingResponses.length; i++) { 3543 var existingResponse = existingResponses[i]; 3544 var response = { description: existingResponse.message }; 3545 if(existingResponse.code === 200) { 3546 has200 = true; 3547 } 3548 // Convert responseModel -> schema{$ref: responseModel} 3549 if(existingResponse.responseModel) { 3550 response.schema = {'$ref': '#/definitions/' + existingResponse.responseModel}; 3551 } 3552 operation.responses['' + existingResponse.code] = response; 3553 } 3554 } 3555 3556 if(has200) { 3557 operation.responses['default'] = defaultResponse; 3558 } 3559 else { 3560 operation.responses['200'] = defaultResponse; 3561 } 3562 }; 3563 3564 SwaggerSpecConverter.prototype.authorizations = function(obj) { 3565 // TODO 3566 if(!_.isObject(obj)) { 3567 return; 3568 } 3569 }; 3570 3571 SwaggerSpecConverter.prototype.parameters = function(operation, obj) { 3572 if(!Array.isArray(obj)) { 3573 return; 3574 } 3575 var i; 3576 for(i = 0; i < obj.length; i++) { 3577 var existingParameter = obj[i]; 3578 var parameter = {}; 3579 parameter.name = existingParameter.name; 3580 parameter.description = existingParameter.description; 3581 parameter.required = existingParameter.required; 3582 parameter.in = existingParameter.paramType; 3583 3584 // per #168 3585 if(parameter.in === 'body') { 3586 parameter.name = 'body'; 3587 } 3588 if(parameter.in === 'form') { 3589 parameter.in = 'formData'; 3590 } 3591 3592 if(existingParameter.enum) { 3593 parameter.enum = existingParameter.enum; 3594 } 3595 3596 if(existingParameter.allowMultiple === true || existingParameter.allowMultiple === 'true') { 3597 var innerType = {}; 3598 this.dataType(existingParameter, innerType); 3599 parameter.type = 'array'; 3600 parameter.items = innerType; 3601 3602 if(existingParameter.allowableValues) { 3603 var av = existingParameter.allowableValues; 3604 if(av.valueType === 'LIST') { 3605 parameter['enum'] = av.values; 3606 } 3607 } 3608 } 3609 else { 3610 this.dataType(existingParameter, parameter); 3611 } 3612 if(typeof existingParameter.defaultValue !== 'undefined') { 3613 parameter.default = existingParameter.defaultValue; 3614 } 3615 3616 operation.parameters = operation.parameters || []; 3617 operation.parameters.push(parameter); 3618 } 3619 }; 3620 3621 SwaggerSpecConverter.prototype.dataType = function(source, target) { 3622 if(!_.isObject(source)) { 3623 return; 3624 } 3625 3626 if(source.minimum) { 3627 target.minimum = source.minimum; 3628 } 3629 if(source.maximum) { 3630 target.maximum = source.maximum; 3631 } 3632 if (source.format) { 3633 target.format = source.format; 3634 } 3635 3636 // default can be 'false' 3637 if(typeof source.defaultValue !== 'undefined') { 3638 target.default = source.defaultValue; 3639 } 3640 3641 var jsonSchemaType = this.toJsonSchema(source); 3642 if(jsonSchemaType) { 3643 target = target || {}; 3644 if(jsonSchemaType.type) { 3645 target.type = jsonSchemaType.type; 3646 } 3647 if(jsonSchemaType.format) { 3648 target.format = jsonSchemaType.format; 3649 } 3650 if(jsonSchemaType.$ref) { 3651 target.schema = {$ref: jsonSchemaType.$ref}; 3652 } 3653 if(jsonSchemaType.items) { 3654 target.items = jsonSchemaType.items; 3655 } 3656 } 3657 }; 3658 3659 SwaggerSpecConverter.prototype.toJsonSchema = function(source) { 3660 if(!source) { 3661 return 'object'; 3662 } 3663 var detectedType = (source.type || source.dataType || source.responseClass || ''); 3664 var lcType = detectedType.toLowerCase(); 3665 var format = (source.format || '').toLowerCase(); 3666 3667 if(lcType.indexOf('list[') === 0) { 3668 var innerType = detectedType.substring(5, detectedType.length - 1); 3669 var jsonType = this.toJsonSchema({type: innerType}); 3670 return {type: 'array', items: jsonType}; 3671 } else if(lcType === 'int' || (lcType === 'integer' && format === 'int32')) { 3672 {return {type: 'integer', format: 'int32'};} 3673 } else if(lcType === 'long' || (lcType === 'integer' && format === 'int64')) { 3674 {return {type: 'integer', format: 'int64'};} 3675 } else if(lcType === 'integer') { 3676 {return {type: 'integer', format: 'int64'};} 3677 } else if(lcType === 'float' || (lcType === 'number' && format === 'float')) { 3678 {return {type: 'number', format: 'float'};} 3679 } else if(lcType === 'double' || (lcType === 'number' && format === 'double')) { 3680 {return {type: 'number', format: 'double'};} 3681 } else if((lcType === 'string' && format === 'date-time') || (lcType === 'date')) { 3682 {return {type: 'string', format: 'date-time'};} 3683 } else if(lcType === 'string') { 3684 {return {type: 'string'};} 3685 } else if(lcType === 'file') { 3686 {return {type: 'file'};} 3687 } else if(lcType === 'boolean') { 3688 {return {type: 'boolean'};} 3689 } else if(lcType === 'boolean') { 3690 {return {type: 'boolean'};} 3691 } else if(lcType === 'array' || lcType === 'list') { 3692 if(source.items) { 3693 var it = this.toJsonSchema(source.items); 3694 return {type: 'array', items: it}; 3695 } 3696 else { 3697 return {type: 'array', items: {type: 'object'}}; 3698 } 3699 } else if(source.$ref) { 3700 return {$ref: this.modelMap[source.$ref] ? '#/definitions/' + this.modelMap[source.$ref] : source.$ref}; 3701 } else if(lcType === 'void' || lcType === '') { 3702 {return {};} 3703 } else if (this.modelMap[source.type]) { 3704 // If this a model using `type` instead of `$ref`, that's fine. 3705 return {$ref: '#/definitions/' + this.modelMap[source.type]}; 3706 } else { 3707 // Unknown model type or 'object', pass it along. 3708 return {type: source.type}; 3709 } 3710 }; 3711 3712 SwaggerSpecConverter.prototype.resourceListing = function(obj, swagger, opts, callback) { 3713 var i; 3714 var processedCount = 0; // jshint ignore:line 3715 var self = this; // jshint ignore:line 3716 var expectedCount = obj.apis.length; 3717 var _swagger = swagger; // jshint ignore:line 3718 var _opts = {}; 3719 3720 if(opts && opts.requestInterceptor){ 3721 _opts.requestInterceptor = opts.requestInterceptor; 3722 } 3723 3724 if(opts && opts.responseInterceptor){ 3725 _opts.responseInterceptor = opts.responseInterceptor; 3726 } 3727 3728 if(expectedCount === 0) { 3729 this.finish(callback, swagger); 3730 } 3731 3732 for(i = 0; i < expectedCount; i++) { 3733 var api = obj.apis[i]; 3734 var path = api.path; 3735 var absolutePath = this.getAbsolutePath(obj.swaggerVersion, this.docLocation, path); 3736 3737 if(api.description) { 3738 swagger.tags = swagger.tags || []; 3739 swagger.tags.push({ 3740 name : this.extractTag(api.path), 3741 description : api.description || '' 3742 }); 3743 } 3744 var http = { 3745 url: absolutePath, 3746 headers: {accept: 'application/json'}, 3747 on: {}, 3748 method: 'get' 3749 }; 3750 /* jshint ignore:start */ 3751 http.on.response = function(data) { 3752 processedCount += 1; 3753 var obj = data.obj; 3754 if(obj) { 3755 self.declaration(obj, _swagger); 3756 } 3757 if(processedCount === expectedCount) { 3758 self.finish(callback, _swagger); 3759 } 3760 }; 3761 http.on.error = function(data) { 3762 console.error(data); 3763 processedCount += 1; 3764 if(processedCount === expectedCount) { 3765 self.finish(callback, _swagger); 3766 } 3767 }; 3768 /* jshint ignore:end */ 3769 3770 if(this.clientAuthorizations && typeof this.clientAuthorizations.apply === 'function') { 3771 this.clientAuthorizations.apply(http); 3772 } 3773 3774 new SwaggerHttp().execute(http, _opts); 3775 } 3776 }; 3777 3778 SwaggerSpecConverter.prototype.getAbsolutePath = function(version, docLocation, path) { 3779 if(version === '1.0') { 3780 if(docLocation.endsWith('.json')) { 3781 // get root path 3782 var pos = docLocation.lastIndexOf('/'); 3783 if(pos > 0) { 3784 docLocation = docLocation.substring(0, pos); 3785 } 3786 } 3787 } 3788 3789 var location = docLocation; 3790 if(path.indexOf('http://') === 0 || path.indexOf('https://') === 0) { 3791 location = path; 3792 } 3793 else { 3794 if(docLocation.endsWith('/')) { 3795 location = docLocation.substring(0, docLocation.length - 1); 3796 } 3797 location += path; 3798 } 3799 location = location.replace('{format}', 'json'); 3800 return location; 3801 }; 3802 3803 SwaggerSpecConverter.prototype.securityDefinitions = function(obj, swagger) { 3804 if(obj.authorizations) { 3805 var name; 3806 for(name in obj.authorizations) { 3807 var isValid = false; 3808 var securityDefinition = {}; 3809 var definition = obj.authorizations[name]; 3810 if(definition.type === 'apiKey') { 3811 securityDefinition.type = 'apiKey'; 3812 securityDefinition.in = definition.passAs; 3813 securityDefinition.name = definition.keyname || name; 3814 isValid = true; 3815 } 3816 else if(definition.type === 'basicAuth') { 3817 securityDefinition.type = 'basicAuth'; 3818 isValid = true; 3819 } 3820 else if(definition.type === 'oauth2') { 3821 var existingScopes = definition.scopes || []; 3822 var scopes = {}; 3823 var i; 3824 for(i in existingScopes) { 3825 var scope = existingScopes[i]; 3826 scopes[scope.scope] = scope.description; 3827 } 3828 securityDefinition.type = 'oauth2'; 3829 if(i > 0) { 3830 securityDefinition.scopes = scopes; 3831 } 3832 if(definition.grantTypes) { 3833 if(definition.grantTypes.implicit) { 3834 var implicit = definition.grantTypes.implicit; 3835 securityDefinition.flow = 'implicit'; 3836 securityDefinition.authorizationUrl = implicit.loginEndpoint; 3837 isValid = true; 3838 } 3839 /* jshint ignore:start */ 3840 if(definition.grantTypes['authorization_code']) { 3841 if(!securityDefinition.flow) { 3842 // cannot set if flow is already defined 3843 var authCode = definition.grantTypes['authorization_code']; 3844 securityDefinition.flow = 'accessCode'; 3845 securityDefinition.authorizationUrl = authCode.tokenRequestEndpoint.url; 3846 securityDefinition.tokenUrl = authCode.tokenEndpoint.url; 3847 isValid = true; 3848 } 3849 } 3850 /* jshint ignore:end */ 3851 } 3852 } 3853 if(isValid) { 3854 swagger.securityDefinitions = swagger.securityDefinitions || {}; 3855 swagger.securityDefinitions[name] = securityDefinition; 3856 } 3857 } 3858 } 3859 }; 3860 3861 SwaggerSpecConverter.prototype.apiInfo = function(obj, swagger) { 3862 // info section 3863 if(obj.info) { 3864 var info = obj.info; 3865 swagger.info = {}; 3866 3867 if(info.contact) { 3868 swagger.info.contact = {}; 3869 swagger.info.contact.email = info.contact; 3870 } 3871 if(info.description) { 3872 swagger.info.description = info.description; 3873 } 3874 if(info.title) { 3875 swagger.info.title = info.title; 3876 } 3877 if(info.termsOfServiceUrl) { 3878 swagger.info.termsOfService = info.termsOfServiceUrl; 3879 } 3880 if(info.license || info.licenseUrl) { 3881 swagger.license = {}; 3882 if(info.license) { 3883 swagger.license.name = info.license; 3884 } 3885 if(info.licenseUrl) { 3886 swagger.license.url = info.licenseUrl; 3887 } 3888 } 3889 } 3890 else { 3891 this.warnings.push('missing info section'); 3892 } 3893 }; 3894 3895 SwaggerSpecConverter.prototype.finish = function (callback, obj) { 3896 callback(obj); 3897 }; 3898 3899 },{"./http":5,"lodash-compat/lang/isObject":148}],9:[function(require,module,exports){ 3900 'use strict'; 3901 3902 var _ = { 3903 isPlainObject: require('lodash-compat/lang/isPlainObject'), 3904 isString: require('lodash-compat/lang/isString'), 3905 }; 3906 3907 var SchemaMarkup = require('../schema-markup.js'); 3908 var jsyaml = require('js-yaml'); 3909 3910 var Model = module.exports = function (name, definition, models, modelPropertyMacro) { 3911 this.definition = definition || {}; 3912 this.isArray = definition.type === 'array'; 3913 this.models = models || {}; 3914 this.name = definition.title || name || 'Inline Model'; 3915 this.modelPropertyMacro = modelPropertyMacro || function (property) { 3916 return property.default; 3917 }; 3918 3919 return this; 3920 }; 3921 3922 Model.prototype.createJSONSample = Model.prototype.getSampleValue = function (modelsToIgnore) { 3923 modelsToIgnore = modelsToIgnore || {}; 3924 3925 modelsToIgnore[this.name] = this; 3926 3927 // Response support 3928 if (this.examples && _.isPlainObject(this.examples) && this.examples['application/json']) { 3929 this.definition.example = this.examples['application/json']; 3930 3931 if (_.isString(this.definition.example)) { 3932 this.definition.example = jsyaml.safeLoad(this.definition.example); 3933 } 3934 } else if (!this.definition.example) { 3935 this.definition.example = this.examples; 3936 } 3937 3938 return SchemaMarkup.schemaToJSON(this.definition, this.models, modelsToIgnore, this.modelPropertyMacro); 3939 }; 3940 3941 Model.prototype.getMockSignature = function () { 3942 return SchemaMarkup.schemaToHTML(this.name, this.definition, this.models, this.modelPropertyMacro); 3943 }; 3944 3945 },{"../schema-markup.js":7,"js-yaml":20,"lodash-compat/lang/isPlainObject":149,"lodash-compat/lang/isString":150}],10:[function(require,module,exports){ 3946 'use strict'; 3947 3948 var _ = { 3949 cloneDeep: require('lodash-compat/lang/cloneDeep'), 3950 isUndefined: require('lodash-compat/lang/isUndefined'), 3951 isEmpty: require('lodash-compat/lang/isEmpty'), 3952 isObject: require('lodash-compat/lang/isObject') 3953 }; 3954 var helpers = require('../helpers'); 3955 var Model = require('./model'); 3956 var SwaggerHttp = require('../http'); 3957 var Q = require('q'); 3958 3959 var Operation = module.exports = function (parent, scheme, operationId, httpMethod, path, args, definitions, models, clientAuthorizations) { 3960 var errors = []; 3961 3962 parent = parent || {}; 3963 args = args || {}; 3964 3965 if(parent && parent.options) { 3966 this.client = parent.options.client || null; 3967 this.requestInterceptor = parent.options.requestInterceptor || null; 3968 this.responseInterceptor = parent.options.responseInterceptor || null; 3969 } 3970 this.authorizations = args.security; 3971 this.basePath = parent.basePath || '/'; 3972 this.clientAuthorizations = clientAuthorizations; 3973 this.consumes = args.consumes || parent.consumes || ['application/json']; 3974 this.produces = args.produces || parent.produces || ['application/json']; 3975 this.deprecated = args.deprecated; 3976 this.description = args.description; 3977 this.host = parent.host || 'localhost'; 3978 this.method = (httpMethod || errors.push('Operation ' + operationId + ' is missing method.')); 3979 this.models = models || {}; 3980 this.nickname = (operationId || errors.push('Operations must have a nickname.')); 3981 this.operation = args; 3982 this.operations = {}; 3983 this.parameters = args !== null ? (args.parameters || []) : {}; 3984 this.parent = parent; 3985 this.path = (path || errors.push('Operation ' + this.nickname + ' is missing path.')); 3986 this.responses = (args.responses || {}); 3987 this.scheme = scheme || parent.scheme || 'http'; 3988 this.schemes = args.schemes || parent.schemes; 3989 this.security = args.security; 3990 this.summary = args.summary || ''; 3991 this.type = null; 3992 this.useJQuery = parent.useJQuery; 3993 this.enableCookies = parent.enableCookies; 3994 this.parameterMacro = parent.parameterMacro || function (operation, parameter) { 3995 return parameter.default; 3996 }; 3997 3998 this.inlineModels = []; 3999 4000 if (typeof this.deprecated === 'string') { 4001 switch(this.deprecated.toLowerCase()) { 4002 case 'true': case 'yes': case '1': { 4003 this.deprecated = true; 4004 break; 4005 } 4006 4007 case 'false': case 'no': case '0': case null: { 4008 this.deprecated = false; 4009 break; 4010 } 4011 4012 default: this.deprecated = Boolean(this.deprecated); 4013 } 4014 } 4015 4016 var i, model; 4017 4018 if (definitions) { 4019 // add to global models 4020 var key; 4021 4022 for (key in definitions) { 4023 model = new Model(key, definitions[key], this.models, parent.modelPropertyMacro); 4024 4025 if (model) { 4026 this.models[key] = model; 4027 } 4028 } 4029 } 4030 else { 4031 definitions = {}; 4032 } 4033 4034 for (i = 0; i < this.parameters.length; i++) { 4035 var param = this.parameters[i]; 4036 4037 // Allow macro to set the default value 4038 param.default = this.parameterMacro(this, param); 4039 4040 if (param.type === 'array') { 4041 param.isList = true; 4042 param.allowMultiple = true; 4043 // the enum can be defined at the items level 4044 //if (param.items && param.items.enum) { 4045 // param['enum'] = param.items.enum; 4046 //} 4047 } 4048 4049 var innerType = this.getType(param); 4050 4051 if (innerType && innerType.toString().toLowerCase() === 'boolean') { 4052 param.allowableValues = {}; 4053 param.isList = true; 4054 param['enum'] = [true, false]; // use actual primitives 4055 } 4056 4057 if(typeof param['x-example'] !== 'undefined') { 4058 var d = param['x-example']; 4059 param.default = d; 4060 } 4061 if(param['x-examples']) { 4062 var d = param['x-examples'].default; 4063 if(typeof d !== 'undefined') { 4064 param.default = d; 4065 } 4066 } 4067 4068 if (typeof param['enum'] !== 'undefined') { 4069 var id; 4070 4071 param.allowableValues = {}; 4072 param.allowableValues.values = []; 4073 param.allowableValues.descriptiveValues = []; 4074 4075 for (id = 0; id < param['enum'].length; id++) { 4076 var value = param['enum'][id]; 4077 var isDefault = (value === param.default || value+'' === param.default); 4078 4079 param.allowableValues.values.push(value); 4080 // Always have string for descriptive values.... 4081 param.allowableValues.descriptiveValues.push({value : value+'', isDefault: isDefault}); 4082 } 4083 } 4084 4085 if (param.type === 'array') { 4086 innerType = [innerType]; 4087 4088 if (typeof param.allowableValues === 'undefined') { 4089 // can't show as a list if no values to select from 4090 delete param.isList; 4091 delete param.allowMultiple; 4092 } 4093 } 4094 4095 param.signature = this.getModelSignature(innerType, this.models).toString(); 4096 param.sampleJSON = this.getModelSampleJSON(innerType, this.models); 4097 param.responseClassSignature = param.signature; 4098 } 4099 4100 var defaultResponseCode, response, responses = this.responses; 4101 4102 if (responses['200']) { 4103 response = responses['200']; 4104 defaultResponseCode = '200'; 4105 } else if (responses['201']) { 4106 response = responses['201']; 4107 defaultResponseCode = '201'; 4108 } else if (responses['202']) { 4109 response = responses['202']; 4110 defaultResponseCode = '202'; 4111 } else if (responses['203']) { 4112 response = responses['203']; 4113 defaultResponseCode = '203'; 4114 } else if (responses['204']) { 4115 response = responses['204']; 4116 defaultResponseCode = '204'; 4117 } else if (responses['205']) { 4118 response = responses['205']; 4119 defaultResponseCode = '205'; 4120 } else if (responses['206']) { 4121 response = responses['206']; 4122 defaultResponseCode = '206'; 4123 } else if (responses['default']) { 4124 response = responses['default']; 4125 defaultResponseCode = 'default'; 4126 } 4127 4128 if (response && response.schema) { 4129 var resolvedModel = this.resolveModel(response.schema, definitions); 4130 var successResponse; 4131 4132 delete responses[defaultResponseCode]; 4133 4134 if (resolvedModel) { 4135 this.successResponse = {}; 4136 successResponse = this.successResponse[defaultResponseCode] = resolvedModel; 4137 } else if (!response.schema.type || response.schema.type === 'object' || response.schema.type === 'array') { 4138 // Inline model 4139 this.successResponse = {}; 4140 successResponse = this.successResponse[defaultResponseCode] = new Model(undefined, response.schema || {}, this.models, parent.modelPropertyMacro); 4141 } else { 4142 // Primitive 4143 this.successResponse = {}; 4144 successResponse = this.successResponse[defaultResponseCode] = response.schema; 4145 } 4146 4147 if (successResponse) { 4148 // Attach response properties 4149 if (response.description) { 4150 successResponse.description = response.description; 4151 } 4152 4153 if (response.examples) { 4154 successResponse.examples = response.examples; 4155 } 4156 4157 if (response.headers) { 4158 successResponse.headers = response.headers; 4159 } 4160 } 4161 4162 this.type = response; 4163 } 4164 4165 if (errors.length > 0) { 4166 if (this.resource && this.resource.api && this.resource.api.fail) { 4167 this.resource.api.fail(errors); 4168 } 4169 } 4170 4171 return this; 4172 }; 4173 4174 Operation.prototype.isDefaultArrayItemValue = function(value, param) { 4175 if (param.default && Array.isArray(param.default)) { 4176 return param.default.indexOf(value) !== -1; 4177 } 4178 return value === param.default; 4179 }; 4180 4181 Operation.prototype.getType = function (param) { 4182 var type = param.type; 4183 var format = param.format; 4184 var isArray = false; 4185 var str; 4186 4187 if (type === 'integer' && format === 'int32') { 4188 str = 'integer'; 4189 } else if (type === 'integer' && format === 'int64') { 4190 str = 'long'; 4191 } else if (type === 'integer') { 4192 str = 'integer'; 4193 } else if (type === 'string') { 4194 if (format === 'date-time') { 4195 str = 'date-time'; 4196 } else if (format === 'date') { 4197 str = 'date'; 4198 } else { 4199 str = 'string'; 4200 } 4201 } else if (type === 'number' && format === 'float') { 4202 str = 'float'; 4203 } else if (type === 'number' && format === 'double') { 4204 str = 'double'; 4205 } else if (type === 'number') { 4206 str = 'double'; 4207 } else if (type === 'boolean') { 4208 str = 'boolean'; 4209 } else if (type === 'array') { 4210 isArray = true; 4211 4212 if (param.items) { 4213 str = this.getType(param.items); 4214 } 4215 } else if (type === 'file') { 4216 str = 'file'; 4217 } 4218 4219 if (param.$ref) { 4220 str = helpers.simpleRef(param.$ref); 4221 } 4222 4223 var schema = param.schema; 4224 4225 if (schema) { 4226 var ref = schema.$ref; 4227 4228 if (ref) { 4229 ref = helpers.simpleRef(ref); 4230 4231 if (isArray) { 4232 return [ ref ]; 4233 } else { 4234 return ref; 4235 } 4236 } else { 4237 // If inline schema, we add it our interal hash -> which gives us it's ID (int) 4238 if(schema.type === 'object') { 4239 return this.addInlineModel(schema); 4240 } 4241 return this.getType(schema); 4242 } 4243 } 4244 if (isArray) { 4245 return [ str ]; 4246 } else { 4247 return str; 4248 } 4249 }; 4250 4251 /** 4252 * adds an inline schema (model) to a hash, where we can ref it later 4253 * @param {object} schema a schema 4254 * @return {number} the ID of the schema being added, or null 4255 **/ 4256 Operation.prototype.addInlineModel = function (schema) { 4257 var len = this.inlineModels.length; 4258 var model = this.resolveModel(schema, {}); 4259 if(model) { 4260 this.inlineModels.push(model); 4261 return 'Inline Model '+len; // return string ref of the inline model (used with #getInlineModel) 4262 } 4263 return null; // report errors? 4264 }; 4265 4266 /** 4267 * gets the internal ref to an inline model 4268 * @param {string} inline_str a string reference to an inline model 4269 * @return {Model} the model being referenced. Or null 4270 **/ 4271 Operation.prototype.getInlineModel = function(inlineStr) { 4272 if(/^Inline Model \d+$/.test(inlineStr)) { 4273 var id = parseInt(inlineStr.substr('Inline Model'.length).trim(),10); // 4274 var model = this.inlineModels[id]; 4275 return model; 4276 } 4277 // I'm returning null here, should I rather throw an error? 4278 return null; 4279 }; 4280 4281 Operation.prototype.resolveModel = function (schema, definitions) { 4282 if (typeof schema.$ref !== 'undefined') { 4283 var ref = schema.$ref; 4284 4285 if (ref.indexOf('#/definitions/') === 0) { 4286 ref = ref.substring('#/definitions/'.length); 4287 } 4288 4289 if (definitions[ref]) { 4290 return new Model(ref, definitions[ref], this.models, this.parent.modelPropertyMacro); 4291 } 4292 // schema must at least be an object to get resolved to an inline Model 4293 } else if (schema && typeof schema === 'object' && 4294 (schema.type === 'object' || _.isUndefined(schema.type))) { 4295 return new Model(undefined, schema, this.models, this.parent.modelPropertyMacro); 4296 } 4297 4298 return null; 4299 }; 4300 4301 Operation.prototype.help = function (dontPrint) { 4302 var out = this.nickname + ': ' + this.summary + '\n'; 4303 4304 for (var i = 0; i < this.parameters.length; i++) { 4305 var param = this.parameters[i]; 4306 var typeInfo = param.signature; 4307 4308 out += '\n * ' + param.name + ' (' + typeInfo + '): ' + param.description; 4309 } 4310 4311 if (typeof dontPrint === 'undefined') { 4312 helpers.log(out); 4313 } 4314 4315 return out; 4316 }; 4317 4318 Operation.prototype.getModelSignature = function (type, definitions) { 4319 var isPrimitive, listType; 4320 4321 if (type instanceof Array) { 4322 listType = true; 4323 type = type[0]; 4324 } 4325 4326 // Convert undefined to string of 'undefined' 4327 if (typeof type === 'undefined') { 4328 type = 'undefined'; 4329 isPrimitive = true; 4330 4331 } else if (definitions[type]){ 4332 // a model def exists? 4333 type = definitions[type]; /* Model */ 4334 isPrimitive = false; 4335 4336 } else if (this.getInlineModel(type)) { 4337 type = this.getInlineModel(type); /* Model */ 4338 isPrimitive = false; 4339 4340 } else { 4341 // We default to primitive 4342 isPrimitive = true; 4343 } 4344 4345 if (isPrimitive) { 4346 if (listType) { 4347 return 'Array[' + type + ']'; 4348 } else { 4349 return type.toString(); 4350 } 4351 } else { 4352 if (listType) { 4353 return 'Array[' + type.getMockSignature() + ']'; 4354 } else { 4355 return type.getMockSignature(); 4356 } 4357 } 4358 }; 4359 4360 Operation.prototype.supportHeaderParams = function () { 4361 return true; 4362 }; 4363 4364 Operation.prototype.supportedSubmitMethods = function () { 4365 return this.parent.supportedSubmitMethods; 4366 }; 4367 4368 Operation.prototype.getHeaderParams = function (args) { 4369 var headers = this.setContentTypes(args, {}); 4370 4371 for (var i = 0; i < this.parameters.length; i++) { 4372 var param = this.parameters[i]; 4373 4374 if (typeof args[param.name] !== 'undefined') { 4375 if (param.in === 'header') { 4376 var value = args[param.name]; 4377 4378 if (Array.isArray(value)) { 4379 value = value.toString(); 4380 } 4381 4382 headers[param.name] = value; 4383 } 4384 } 4385 } 4386 4387 return headers; 4388 }; 4389 4390 Operation.prototype.urlify = function (args) { 4391 var formParams = {}; 4392 var requestUrl = this.path; 4393 var querystring = ''; // grab params from the args, build the querystring along the way 4394 4395 for (var i = 0; i < this.parameters.length; i++) { 4396 var param = this.parameters[i]; 4397 4398 if (typeof args[param.name] !== 'undefined') { 4399 if (param.in === 'path') { 4400 var reg = new RegExp('\{' + param.name + '\}', 'gi'); 4401 var value = args[param.name]; 4402 4403 if (Array.isArray(value)) { 4404 value = this.encodePathCollection(param.collectionFormat, param.name, value); 4405 } else { 4406 value = this.encodePathParam(value); 4407 } 4408 4409 requestUrl = requestUrl.replace(reg, value); 4410 } else if (param.in === 'query' && typeof args[param.name] !== 'undefined') { 4411 if (querystring === '') { 4412 querystring += '?'; 4413 } else { 4414 querystring += '&'; 4415 } 4416 4417 if (typeof param.collectionFormat !== 'undefined') { 4418 var qp = args[param.name]; 4419 4420 if (Array.isArray(qp)) { 4421 querystring += this.encodeQueryCollection(param.collectionFormat, param.name, qp); 4422 } else { 4423 querystring += this.encodeQueryParam(param.name) + '=' + this.encodeQueryParam(args[param.name]); 4424 } 4425 } else { 4426 querystring += this.encodeQueryParam(param.name) + '=' + this.encodeQueryParam(args[param.name]); 4427 } 4428 } else if (param.in === 'formData') { 4429 formParams[param.name] = args[param.name]; 4430 } 4431 } 4432 } 4433 var url = this.scheme + '://' + this.host; 4434 4435 if (this.basePath !== '/') { 4436 url += this.basePath; 4437 } 4438 return url + requestUrl + querystring; 4439 }; 4440 4441 Operation.prototype.getMissingParams = function (args) { 4442 var missingParams = []; // check required params, track the ones that are missing 4443 var i; 4444 4445 for (i = 0; i < this.parameters.length; i++) { 4446 var param = this.parameters[i]; 4447 4448 if (param.required === true) { 4449 if (typeof args[param.name] === 'undefined') { 4450 missingParams = param.name; 4451 } 4452 } 4453 } 4454 4455 return missingParams; 4456 }; 4457 4458 Operation.prototype.getBody = function (headers, args, opts) { 4459 var formParams = {}, hasFormParams, body, key, value, hasBody = false; 4460 4461 // look at each param and put form params in an object 4462 for (var i = 0; i < this.parameters.length; i++) { 4463 var param = this.parameters[i]; 4464 if (typeof args[param.name] !== 'undefined') { 4465 if (param.in === 'body') { 4466 body = args[param.name]; 4467 } else if (param.in === 'formData') { 4468 formParams[param.name] = args[param.name]; 4469 hasFormParams = true; 4470 } 4471 } 4472 else { 4473 if(param.in === 'body') { 4474 hasBody = true; 4475 } 4476 } 4477 } 4478 4479 // if body is null and hasBody is true, AND a JSON body is requested, send empty {} 4480 if(hasBody && typeof body === 'undefined') { 4481 var contentType = headers['Content-Type']; 4482 if(contentType && contentType.indexOf('application/json') === 0) { 4483 body = '{}'; 4484 } 4485 } 4486 4487 var isMultiPart = false; 4488 if(headers['Content-Type'] && headers['Content-Type'].indexOf('multipart/form-data') >= 0) { 4489 isMultiPart = true; 4490 } 4491 4492 // handle form params 4493 if (hasFormParams && !isMultiPart) { 4494 var encoded = ''; 4495 4496 for (key in formParams) { 4497 value = formParams[key]; 4498 4499 if (typeof value !== 'undefined') { 4500 if (encoded !== '') { 4501 encoded += '&'; 4502 } 4503 4504 encoded += encodeURIComponent(key) + '=' + encodeURIComponent(value); 4505 } 4506 } 4507 4508 body = encoded; 4509 } else if (isMultiPart) { 4510 if (opts.useJQuery) { 4511 var bodyParam = new FormData(); 4512 4513 bodyParam.type = 'formData'; 4514 4515 for (key in formParams) { 4516 value = args[key]; 4517 4518 if (typeof value !== 'undefined') { 4519 // required for jquery file upload 4520 if (value.type === 'file' && value.value) { 4521 delete headers['Content-Type']; 4522 4523 bodyParam.append(key, value.value); 4524 } else { 4525 bodyParam.append(key, value); 4526 } 4527 } 4528 } 4529 4530 body = bodyParam; 4531 } 4532 } 4533 4534 return body; 4535 }; 4536 4537 /** 4538 * gets sample response for a single operation 4539 **/ 4540 Operation.prototype.getModelSampleJSON = function (type, models) { 4541 var listType, sampleJson, innerType; 4542 models = models || {}; 4543 4544 listType = (type instanceof Array); 4545 innerType = listType ? type[0] : type; 4546 4547 if(models[innerType]) { 4548 sampleJson = models[innerType].createJSONSample(); 4549 } else if (this.getInlineModel(innerType)){ 4550 sampleJson = this.getInlineModel(innerType).createJSONSample(); // may return null, if type isn't correct 4551 } 4552 4553 4554 if (sampleJson) { 4555 sampleJson = listType ? [sampleJson] : sampleJson; 4556 4557 if (typeof sampleJson === 'string') { 4558 return sampleJson; 4559 } else if (_.isObject(sampleJson)) { 4560 var t = sampleJson; 4561 4562 if (sampleJson instanceof Array && sampleJson.length > 0) { 4563 t = sampleJson[0]; 4564 } 4565 4566 if (t.nodeName && typeof t === 'Node') { 4567 var xmlString = new XMLSerializer().serializeToString(t); 4568 4569 return this.formatXml(xmlString); 4570 } else { 4571 return JSON.stringify(sampleJson, null, 2); 4572 } 4573 } else { 4574 return sampleJson; 4575 } 4576 } 4577 }; 4578 4579 /** 4580 * legacy binding 4581 **/ 4582 Operation.prototype.do = function (args, opts, callback, error, parent) { 4583 return this.execute(args, opts, callback, error, parent); 4584 }; 4585 4586 /** 4587 * executes an operation 4588 **/ 4589 Operation.prototype.execute = function (arg1, arg2, arg3, arg4, parent) { 4590 var args = arg1 || {}; 4591 var opts = {}, success, error, deferred; 4592 4593 if (_.isObject(arg2)) { 4594 opts = arg2; 4595 success = arg3; 4596 error = arg4; 4597 } 4598 4599 if(this.client) { 4600 opts.client = this.client; 4601 } 4602 4603 // add the request interceptor from parent, if none sent from client 4604 if(!opts.requestInterceptor && this.requestInterceptor ) { 4605 opts.requestInterceptor = this.requestInterceptor ; 4606 } 4607 4608 if(!opts.responseInterceptor && this.responseInterceptor) { 4609 opts.responseInterceptor = this.responseInterceptor; 4610 } 4611 4612 if (typeof arg2 === 'function') { 4613 success = arg2; 4614 error = arg3; 4615 } 4616 4617 if (this.parent.usePromise) { 4618 deferred = Q.defer(); 4619 } else { 4620 success = (success || this.parent.defaultSuccessCallback || helpers.log); 4621 error = (error || this.parent.defaultErrorCallback || helpers.log); 4622 } 4623 4624 4625 if (typeof opts.useJQuery === 'undefined') { 4626 opts.useJQuery = this.useJQuery; 4627 } 4628 4629 if (typeof opts.enableCookies === 'undefined') { 4630 opts.enableCookies = this.enableCookies; 4631 } 4632 4633 var missingParams = this.getMissingParams(args); 4634 4635 if (missingParams.length > 0) { 4636 var message = 'missing required params: ' + missingParams; 4637 4638 helpers.fail(message); 4639 4640 if (this.parent.usePromise) { 4641 deferred.reject(message); 4642 return deferred.promise; 4643 } else { 4644 error(message, parent); 4645 return {}; 4646 } 4647 } 4648 4649 var allHeaders = this.getHeaderParams(args); 4650 var contentTypeHeaders = this.setContentTypes(args, opts); 4651 var headers = {}, attrname; 4652 4653 for (attrname in allHeaders) { headers[attrname] = allHeaders[attrname]; } 4654 for (attrname in contentTypeHeaders) { headers[attrname] = contentTypeHeaders[attrname]; } 4655 4656 var body = this.getBody(contentTypeHeaders, args, opts); 4657 var url = this.urlify(args); 4658 4659 if(url.indexOf('.{format}') > 0) { 4660 if(headers) { 4661 var format = headers.Accept || headers.accept; 4662 if(format && format.indexOf('json') > 0) { 4663 url = url.replace('.{format}', '.json'); 4664 } 4665 else if(format && format.indexOf('xml') > 0) { 4666 url = url.replace('.{format}', '.xml'); 4667 } 4668 } 4669 } 4670 4671 var obj = { 4672 url: url, 4673 method: this.method.toUpperCase(), 4674 body: body, 4675 enableCookies: opts.enableCookies, 4676 useJQuery: opts.useJQuery, 4677 deferred: deferred, 4678 headers: headers, 4679 on: { 4680 response: function (response) { 4681 if (deferred) { 4682 deferred.resolve(response); 4683 return deferred.promise; 4684 } else { 4685 return success(response, parent); 4686 } 4687 }, 4688 error: function (response) { 4689 if (deferred) { 4690 deferred.reject(response); 4691 return deferred.promise; 4692 } else { 4693 return error(response, parent); 4694 } 4695 } 4696 } 4697 }; 4698 4699 this.clientAuthorizations.apply(obj, this.operation.security); 4700 if (opts.mock === true) { 4701 return obj; 4702 } else { 4703 return new SwaggerHttp().execute(obj, opts); 4704 } 4705 }; 4706 4707 function itemByPriority(col, itemPriority) { 4708 4709 // No priorities? return first... 4710 if(_.isEmpty(itemPriority)) { 4711 return col[0]; 4712 } 4713 4714 for (var i = 0, len = itemPriority.length; i < len; i++) { 4715 if(col.indexOf(itemPriority[i]) > -1) { 4716 return itemPriority[i]; 4717 } 4718 } 4719 4720 // Otherwise return first 4721 return col[0]; 4722 } 4723 4724 Operation.prototype.setContentTypes = function (args, opts) { 4725 // default type 4726 var allDefinedParams = this.parameters; 4727 var body; 4728 var consumes = args.parameterContentType || itemByPriority(this.consumes, ['application/json', 'application/yaml']); 4729 var accepts = opts.responseContentType || itemByPriority(this.produces, ['application/json', 'application/yaml']); 4730 var definedFileParams = []; 4731 var definedFormParams = []; 4732 var headers = {}; 4733 var i; 4734 4735 // get params from the operation and set them in definedFileParams, definedFormParams, headers 4736 for (i = 0; i < allDefinedParams.length; i++) { 4737 var param = allDefinedParams[i]; 4738 4739 if (param.in === 'formData') { 4740 if (param.type === 'file') { 4741 definedFileParams.push(param); 4742 } else { 4743 definedFormParams.push(param); 4744 } 4745 } else if (param.in === 'header' && opts) { 4746 var key = param.name; 4747 var headerValue = opts[param.name]; 4748 4749 if (typeof opts[param.name] !== 'undefined') { 4750 headers[key] = headerValue; 4751 } 4752 } else if (param.in === 'body' && typeof args[param.name] !== 'undefined') { 4753 body = args[param.name]; 4754 } 4755 } 4756 4757 // if there's a body, need to set the consumes header via requestContentType 4758 if (this.method === 'post' || this.method === 'put' || this.method === 'patch' || 4759 ((this.method === 'delete' || this.method === 'get') && body) ) { 4760 if (opts.requestContentType) { 4761 consumes = opts.requestContentType; 4762 } 4763 // if any form params, content type must be set 4764 if (definedFormParams.length > 0) { 4765 if (opts.requestContentType) { // override if set 4766 consumes = opts.requestContentType; 4767 } else if (definedFileParams.length > 0) { // if a file, must be multipart/form-data 4768 consumes = 'multipart/form-data'; 4769 } else { // default to x-www-from-urlencoded 4770 consumes = 'application/x-www-form-urlencoded'; 4771 } 4772 } 4773 } 4774 else { 4775 consumes = null; 4776 } 4777 4778 if (consumes && this.consumes) { 4779 if (this.consumes.indexOf(consumes) === -1) { 4780 helpers.log('server doesn\'t consume ' + consumes + ', try ' + JSON.stringify(this.consumes)); 4781 } 4782 } 4783 4784 if (!this.matchesAccept(accepts)) { 4785 helpers.log('server can\'t produce ' + accepts); 4786 } 4787 4788 if ((consumes && body !== '') || (consumes === 'application/x-www-form-urlencoded')) { 4789 headers['Content-Type'] = consumes; 4790 } 4791 4792 if (accepts) { 4793 headers.Accept = accepts; 4794 } 4795 4796 return headers; 4797 }; 4798 4799 /** 4800 * Returns true if the request accepts header matches anything in this.produces. 4801 * If this.produces contains * / *, ignore the accept header. 4802 * @param {string=} accepts The client request accept header. 4803 * @return {boolean} 4804 */ 4805 Operation.prototype.matchesAccept = function(accepts) { 4806 // no accepts or produces, no problem! 4807 if (!accepts || !this.produces) { 4808 return true; 4809 } 4810 return this.produces.indexOf(accepts) !== -1 || this.produces.indexOf('*/*') !== -1; 4811 }; 4812 4813 Operation.prototype.asCurl = function (args1, args2) { 4814 var opts = {mock: true}; 4815 if (typeof args2 === 'object') { 4816 for (var argKey in args2) { 4817 opts[argKey] = args2[argKey]; 4818 } 4819 } 4820 var obj = this.execute(args1, opts); 4821 4822 this.clientAuthorizations.apply(obj, this.operation.security); 4823 4824 var results = []; 4825 4826 results.push('-X ' + this.method.toUpperCase()); 4827 4828 if (typeof obj.headers !== 'undefined') { 4829 var key; 4830 4831 for (key in obj.headers) { 4832 var value = obj.headers[key]; 4833 if(typeof value === 'string'){ 4834 value = value.replace(/\'/g, '\\u0027'); 4835 } 4836 results.push('--header \'' + key + ': ' + value + '\''); 4837 } 4838 } 4839 4840 if (obj.body) { 4841 var body; 4842 4843 if (_.isObject(obj.body)) { 4844 body = JSON.stringify(obj.body); 4845 } else { 4846 body = obj.body; 4847 } 4848 4849 results.push('-d \'' + body.replace(/\'/g, '\\u0027') + '\''); 4850 } 4851 4852 return 'curl ' + (results.join(' ')) + ' \'' + obj.url + '\''; 4853 }; 4854 4855 Operation.prototype.encodePathCollection = function (type, name, value) { 4856 var encoded = ''; 4857 var i; 4858 var separator = ''; 4859 4860 if (type === 'ssv') { 4861 separator = '%20'; 4862 } else if (type === 'tsv') { 4863 separator = '\\t'; 4864 } else if (type === 'pipes') { 4865 separator = '|'; 4866 } else { 4867 separator = ','; 4868 } 4869 4870 for (i = 0; i < value.length; i++) { 4871 if (i === 0) { 4872 encoded = this.encodeQueryParam(value[i]); 4873 } else { 4874 encoded += separator + this.encodeQueryParam(value[i]); 4875 } 4876 } 4877 4878 return encoded; 4879 }; 4880 4881 Operation.prototype.encodeQueryCollection = function (type, name, value) { 4882 var encoded = ''; 4883 var i; 4884 4885 if (type === 'default' || type === 'multi') { 4886 for (i = 0; i < value.length; i++) { 4887 if (i > 0) {encoded += '&';} 4888 4889 encoded += this.encodeQueryParam(name) + '=' + this.encodeQueryParam(value[i]); 4890 } 4891 } else { 4892 var separator = ''; 4893 4894 if (type === 'csv') { 4895 separator = ','; 4896 } else if (type === 'ssv') { 4897 separator = '%20'; 4898 } else if (type === 'tsv') { 4899 separator = '\\t'; 4900 } else if (type === 'pipes') { 4901 separator = '|'; 4902 } else if (type === 'brackets') { 4903 for (i = 0; i < value.length; i++) { 4904 if (i !== 0) { 4905 encoded += '&'; 4906 } 4907 4908 encoded += this.encodeQueryParam(name) + '[]=' + this.encodeQueryParam(value[i]); 4909 } 4910 } 4911 4912 if (separator !== '') { 4913 for (i = 0; i < value.length; i++) { 4914 if (i === 0) { 4915 encoded = this.encodeQueryParam(name) + '=' + this.encodeQueryParam(value[i]); 4916 } else { 4917 encoded += separator + this.encodeQueryParam(value[i]); 4918 } 4919 } 4920 } 4921 } 4922 4923 return encoded; 4924 }; 4925 4926 Operation.prototype.encodeQueryParam = function (arg) { 4927 return encodeURIComponent(arg); 4928 }; 4929 4930 /** 4931 * TODO revisit, might not want to leave '/' 4932 **/ 4933 Operation.prototype.encodePathParam = function (pathParam) { 4934 return encodeURIComponent(pathParam); 4935 }; 4936 4937 },{"../helpers":4,"../http":5,"./model":9,"lodash-compat/lang/cloneDeep":142,"lodash-compat/lang/isEmpty":145,"lodash-compat/lang/isObject":148,"lodash-compat/lang/isUndefined":152,"q":161}],11:[function(require,module,exports){ 4938 'use strict'; 4939 4940 var OperationGroup = module.exports = function (tag, description, externalDocs, operation) { 4941 this.description = description; 4942 this.externalDocs = externalDocs; 4943 this.name = tag; 4944 this.operation = operation; 4945 this.operationsArray = []; 4946 this.path = tag; 4947 this.tag = tag; 4948 }; 4949 4950 OperationGroup.prototype.sort = function () { 4951 4952 }; 4953 4954 4955 },{}],12:[function(require,module,exports){ 4956 4957 },{}],13:[function(require,module,exports){ 4958 // shim for using process in browser 4959 4960 var process = module.exports = {}; 4961 var queue = []; 4962 var draining = false; 4963 4964 function drainQueue() { 4965 if (draining) { 4966 return; 4967 } 4968 draining = true; 4969 var currentQueue; 4970 var len = queue.length; 4971 while(len) { 4972 currentQueue = queue; 4973 queue = []; 4974 var i = -1; 4975 while (++i < len) { 4976 currentQueue[i](); 4977 } 4978 len = queue.length; 4979 } 4980 draining = false; 4981 } 4982 process.nextTick = function (fun) { 4983 queue.push(fun); 4984 if (!draining) { 4985 setTimeout(drainQueue, 0); 4986 } 4987 }; 4988 4989 process.title = 'browser'; 4990 process.browser = true; 4991 process.env = {}; 4992 process.argv = []; 4993 process.version = ''; // empty string to avoid regexp issues 4994 process.versions = {}; 4995 4996 function noop() {} 4997 4998 process.on = noop; 4999 process.addListener = noop; 5000 process.once = noop; 5001 process.off = noop; 5002 process.removeListener = noop; 5003 process.removeAllListeners = noop; 5004 process.emit = noop; 5005 5006 process.binding = function (name) { 5007 throw new Error('process.binding is not supported'); 5008 }; 5009 5010 // TODO(shtylman) 5011 process.cwd = function () { return '/' }; 5012 process.chdir = function (dir) { 5013 throw new Error('process.chdir is not supported'); 5014 }; 5015 process.umask = function() { return 0; }; 5016 5017 },{}],14:[function(require,module,exports){ 5018 (function (Buffer){ 5019 (function () { 5020 "use strict"; 5021 5022 function btoa(str) { 5023 var buffer 5024 ; 5025 5026 if (str instanceof Buffer) { 5027 buffer = str; 5028 } else { 5029 buffer = new Buffer(str.toString(), 'binary'); 5030 } 5031 5032 return buffer.toString('base64'); 5033 } 5034 5035 module.exports = btoa; 5036 }()); 5037 5038 }).call(this,require("buffer").Buffer) 5039 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9idG9hL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICgpIHtcbiAgXCJ1c2Ugc3RyaWN0XCI7XG5cbiAgZnVuY3Rpb24gYnRvYShzdHIpIHtcbiAgICB2YXIgYnVmZmVyXG4gICAgICA7XG5cbiAgICBpZiAoc3RyIGluc3RhbmNlb2YgQnVmZmVyKSB7XG4gICAgICBidWZmZXIgPSBzdHI7XG4gICAgfSBlbHNlIHtcbiAgICAgIGJ1ZmZlciA9IG5ldyBCdWZmZXIoc3RyLnRvU3RyaW5nKCksICdiaW5hcnknKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYnVmZmVyLnRvU3RyaW5nKCdiYXNlNjQnKTtcbiAgfVxuXG4gIG1vZHVsZS5leHBvcnRzID0gYnRvYTtcbn0oKSk7XG4iXX0= 5040 },{"buffer":15}],15:[function(require,module,exports){ 5041 /*! 5042 * The buffer module from node.js, for the browser. 5043 * 5044 * @author Feross Aboukhadijeh <feross@feross.org> <http://feross.org> 5045 * @license MIT 5046 */ 5047 5048 var base64 = require('base64-js') 5049 var ieee754 = require('ieee754') 5050 var isArray = require('is-array') 5051 5052 exports.Buffer = Buffer 5053 exports.SlowBuffer = SlowBuffer 5054 exports.INSPECT_MAX_BYTES = 50 5055 Buffer.poolSize = 8192 // not used by this implementation 5056 5057 var rootParent = {} 5058 5059 /** 5060 * If `Buffer.TYPED_ARRAY_SUPPORT`: 5061 * === true Use Uint8Array implementation (fastest) 5062 * === false Use Object implementation (most compatible, even IE6) 5063 * 5064 * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, 5065 * Opera 11.6+, iOS 4.2+. 5066 * 5067 * Due to various browser bugs, sometimes the Object implementation will be used even 5068 * when the browser supports typed arrays. 5069 * 5070 * Note: 5071 * 5072 * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, 5073 * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. 5074 * 5075 * - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property 5076 * on objects. 5077 * 5078 * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. 5079 * 5080 * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of 5081 * incorrect length in some situations. 5082 5083 * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they 5084 * get the Object implementation, which is slower but behaves correctly. 5085 */ 5086 Buffer.TYPED_ARRAY_SUPPORT = (function () { 5087 function Bar () {} 5088 try { 5089 var arr = new Uint8Array(1) 5090 arr.foo = function () { return 42 } 5091 arr.constructor = Bar 5092 return arr.foo() === 42 && // typed array instances can be augmented 5093 arr.constructor === Bar && // constructor can be set 5094 typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray` 5095 arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray` 5096 } catch (e) { 5097 return false 5098 } 5099 })() 5100 5101 function kMaxLength () { 5102 return Buffer.TYPED_ARRAY_SUPPORT 5103 ? 0x7fffffff 5104 : 0x3fffffff 5105 } 5106 5107 /** 5108 * Class: Buffer 5109 * ============= 5110 * 5111 * The Buffer constructor returns instances of `Uint8Array` that are augmented 5112 * with function properties for all the node `Buffer` API functions. We use 5113 * `Uint8Array` so that square bracket notation works as expected -- it returns 5114 * a single octet. 5115 * 5116 * By augmenting the instances, we can avoid modifying the `Uint8Array` 5117 * prototype. 5118 */ 5119 function Buffer (arg) { 5120 if (!(this instanceof Buffer)) { 5121 // Avoid going through an ArgumentsAdaptorTrampoline in the common case. 5122 if (arguments.length > 1) return new Buffer(arg, arguments[1]) 5123 return new Buffer(arg) 5124 } 5125 5126 this.length = 0 5127 this.parent = undefined 5128 5129 // Common case. 5130 if (typeof arg === 'number') { 5131 return fromNumber(this, arg) 5132 } 5133 5134 // Slightly less common case. 5135 if (typeof arg === 'string') { 5136 return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8') 5137 } 5138 5139 // Unusual. 5140 return fromObject(this, arg) 5141 } 5142 5143 function fromNumber (that, length) { 5144 that = allocate(that, length < 0 ? 0 : checked(length) | 0) 5145 if (!Buffer.TYPED_ARRAY_SUPPORT) { 5146 for (var i = 0; i < length; i++) { 5147 that[i] = 0 5148 } 5149 } 5150 return that 5151 } 5152 5153 function fromString (that, string, encoding) { 5154 if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8' 5155 5156 // Assumption: byteLength() return value is always < kMaxLength. 5157 var length = byteLength(string, encoding) | 0 5158 that = allocate(that, length) 5159 5160 that.write(string, encoding) 5161 return that 5162 } 5163 5164 function fromObject (that, object) { 5165 if (Buffer.isBuffer(object)) return fromBuffer(that, object) 5166 5167 if (isArray(object)) return fromArray(that, object) 5168 5169 if (object == null) { 5170 throw new TypeError('must start with number, buffer, array or string') 5171 } 5172 5173 if (typeof ArrayBuffer !== 'undefined') { 5174 if (object.buffer instanceof ArrayBuffer) { 5175 return fromTypedArray(that, object) 5176 } 5177 if (object instanceof ArrayBuffer) { 5178 return fromArrayBuffer(that, object) 5179 } 5180 } 5181 5182 if (object.length) return fromArrayLike(that, object) 5183 5184 return fromJsonObject(that, object) 5185 } 5186 5187 function fromBuffer (that, buffer) { 5188 var length = checked(buffer.length) | 0 5189 that = allocate(that, length) 5190 buffer.copy(that, 0, 0, length) 5191 return that 5192 } 5193 5194 function fromArray (that, array) { 5195 var length = checked(array.length) | 0 5196 that = allocate(that, length) 5197 for (var i = 0; i < length; i += 1) { 5198 that[i] = array[i] & 255 5199 } 5200 return that 5201 } 5202 5203 // Duplicate of fromArray() to keep fromArray() monomorphic. 5204 function fromTypedArray (that, array) { 5205 var length = checked(array.length) | 0 5206 that = allocate(that, length) 5207 // Truncating the elements is probably not what people expect from typed 5208 // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior 5209 // of the old Buffer constructor. 5210 for (var i = 0; i < length; i += 1) { 5211 that[i] = array[i] & 255 5212 } 5213 return that 5214 } 5215 5216 function fromArrayBuffer (that, array) { 5217 if (Buffer.TYPED_ARRAY_SUPPORT) { 5218 // Return an augmented `Uint8Array` instance, for best performance 5219 array.byteLength 5220 that = Buffer._augment(new Uint8Array(array)) 5221 } else { 5222 // Fallback: Return an object instance of the Buffer class 5223 that = fromTypedArray(that, new Uint8Array(array)) 5224 } 5225 return that 5226 } 5227 5228 function fromArrayLike (that, array) { 5229 var length = checked(array.length) | 0 5230 that = allocate(that, length) 5231 for (var i = 0; i < length; i += 1) { 5232 that[i] = array[i] & 255 5233 } 5234 return that 5235 } 5236 5237 // Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object. 5238 // Returns a zero-length buffer for inputs that don't conform to the spec. 5239 function fromJsonObject (that, object) { 5240 var array 5241 var length = 0 5242 5243 if (object.type === 'Buffer' && isArray(object.data)) { 5244 array = object.data 5245 length = checked(array.length) | 0 5246 } 5247 that = allocate(that, length) 5248 5249 for (var i = 0; i < length; i += 1) { 5250 that[i] = array[i] & 255 5251 } 5252 return that 5253 } 5254 5255 function allocate (that, length) { 5256 if (Buffer.TYPED_ARRAY_SUPPORT) { 5257 // Return an augmented `Uint8Array` instance, for best performance 5258 that = Buffer._augment(new Uint8Array(length)) 5259 } else { 5260 // Fallback: Return an object instance of the Buffer class 5261 that.length = length 5262 that._isBuffer = true 5263 } 5264 5265 var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1 5266 if (fromPool) that.parent = rootParent 5267 5268 return that 5269 } 5270 5271 function checked (length) { 5272 // Note: cannot use `length < kMaxLength` here because that fails when 5273 // length is NaN (which is otherwise coerced to zero.) 5274 if (length >= kMaxLength()) { 5275 throw new RangeError('Attempt to allocate Buffer larger than maximum ' + 5276 'size: 0x' + kMaxLength().toString(16) + ' bytes') 5277 } 5278 return length | 0 5279 } 5280 5281 function SlowBuffer (subject, encoding) { 5282 if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding) 5283 5284 var buf = new Buffer(subject, encoding) 5285 delete buf.parent 5286 return buf 5287 } 5288 5289 Buffer.isBuffer = function isBuffer (b) { 5290 return !!(b != null && b._isBuffer) 5291 } 5292 5293 Buffer.compare = function compare (a, b) { 5294 if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) { 5295 throw new TypeError('Arguments must be Buffers') 5296 } 5297 5298 if (a === b) return 0 5299 5300 var x = a.length 5301 var y = b.length 5302 5303 var i = 0 5304 var len = Math.min(x, y) 5305 while (i < len) { 5306 if (a[i] !== b[i]) break 5307 5308 ++i 5309 } 5310 5311 if (i !== len) { 5312 x = a[i] 5313 y = b[i] 5314 } 5315 5316 if (x < y) return -1 5317 if (y < x) return 1 5318 return 0 5319 } 5320 5321 Buffer.isEncoding = function isEncoding (encoding) { 5322 switch (String(encoding).toLowerCase()) { 5323 case 'hex': 5324 case 'utf8': 5325 case 'utf-8': 5326 case 'ascii': 5327 case 'binary': 5328 case 'base64': 5329 case 'raw': 5330 case 'ucs2': 5331 case 'ucs-2': 5332 case 'utf16le': 5333 case 'utf-16le': 5334 return true 5335 default: 5336 return false 5337 } 5338 } 5339 5340 Buffer.concat = function concat (list, length) { 5341 if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.') 5342 5343 if (list.length === 0) { 5344 return new Buffer(0) 5345 } 5346 5347 var i 5348 if (length === undefined) { 5349 length = 0 5350 for (i = 0; i < list.length; i++) { 5351 length += list[i].length 5352 } 5353 } 5354 5355 var buf = new Buffer(length) 5356 var pos = 0 5357 for (i = 0; i < list.length; i++) { 5358 var item = list[i] 5359 item.copy(buf, pos) 5360 pos += item.length 5361 } 5362 return buf 5363 } 5364 5365 function byteLength (string, encoding) { 5366 if (typeof string !== 'string') string = '' + string 5367 5368 var len = string.length 5369 if (len === 0) return 0 5370 5371 // Use a for loop to avoid recursion 5372 var loweredCase = false 5373 for (;;) { 5374 switch (encoding) { 5375 case 'ascii': 5376 case 'binary': 5377 // Deprecated 5378 case 'raw': 5379 case 'raws': 5380 return len 5381 case 'utf8': 5382 case 'utf-8': 5383 return utf8ToBytes(string).length 5384 case 'ucs2': 5385 case 'ucs-2': 5386 case 'utf16le': 5387 case 'utf-16le': 5388 return len * 2 5389 case 'hex': 5390 return len >>> 1 5391 case 'base64': 5392 return base64ToBytes(string).length 5393 default: 5394 if (loweredCase) return utf8ToBytes(string).length // assume utf8 5395 encoding = ('' + encoding).toLowerCase() 5396 loweredCase = true 5397 } 5398 } 5399 } 5400 Buffer.byteLength = byteLength 5401 5402 // pre-set for values that may exist in the future 5403 Buffer.prototype.length = undefined 5404 Buffer.prototype.parent = undefined 5405 5406 function slowToString (encoding, start, end) { 5407 var loweredCase = false 5408 5409 start = start | 0 5410 end = end === undefined || end === Infinity ? this.length : end | 0 5411 5412 if (!encoding) encoding = 'utf8' 5413 if (start < 0) start = 0 5414 if (end > this.length) end = this.length 5415 if (end <= start) return '' 5416 5417 while (true) { 5418 switch (encoding) { 5419 case 'hex': 5420 return hexSlice(this, start, end) 5421 5422 case 'utf8': 5423 case 'utf-8': 5424 return utf8Slice(this, start, end) 5425 5426 case 'ascii': 5427 return asciiSlice(this, start, end) 5428 5429 case 'binary': 5430 return binarySlice(this, start, end) 5431 5432 case 'base64': 5433 return base64Slice(this, start, end) 5434 5435 case 'ucs2': 5436 case 'ucs-2': 5437 case 'utf16le': 5438 case 'utf-16le': 5439 return utf16leSlice(this, start, end) 5440 5441 default: 5442 if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) 5443 encoding = (encoding + '').toLowerCase() 5444 loweredCase = true 5445 } 5446 } 5447 } 5448 5449 Buffer.prototype.toString = function toString () { 5450 var length = this.length | 0 5451 if (length === 0) return '' 5452 if (arguments.length === 0) return utf8Slice(this, 0, length) 5453 return slowToString.apply(this, arguments) 5454 } 5455 5456 Buffer.prototype.equals = function equals (b) { 5457 if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') 5458 if (this === b) return true 5459 return Buffer.compare(this, b) === 0 5460 } 5461 5462 Buffer.prototype.inspect = function inspect () { 5463 var str = '' 5464 var max = exports.INSPECT_MAX_BYTES 5465 if (this.length > 0) { 5466 str = this.toString('hex', 0, max).match(/.{2}/g).join(' ') 5467 if (this.length > max) str += ' ... ' 5468 } 5469 return '<Buffer ' + str + '>' 5470 } 5471 5472 Buffer.prototype.compare = function compare (b) { 5473 if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') 5474 if (this === b) return 0 5475 return Buffer.compare(this, b) 5476 } 5477 5478 Buffer.prototype.indexOf = function indexOf (val, byteOffset) { 5479 if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff 5480 else if (byteOffset < -0x80000000) byteOffset = -0x80000000 5481 byteOffset >>= 0 5482 5483 if (this.length === 0) return -1 5484 if (byteOffset >= this.length) return -1 5485 5486 // Negative offsets start from the end of the buffer 5487 if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0) 5488 5489 if (typeof val === 'string') { 5490 if (val.length === 0) return -1 // special case: looking for empty string always fails 5491 return String.prototype.indexOf.call(this, val, byteOffset) 5492 } 5493 if (Buffer.isBuffer(val)) { 5494 return arrayIndexOf(this, val, byteOffset) 5495 } 5496 if (typeof val === 'number') { 5497 if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') { 5498 return Uint8Array.prototype.indexOf.call(this, val, byteOffset) 5499 } 5500 return arrayIndexOf(this, [ val ], byteOffset) 5501 } 5502 5503 function arrayIndexOf (arr, val, byteOffset) { 5504 var foundIndex = -1 5505 for (var i = 0; byteOffset + i < arr.length; i++) { 5506 if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) { 5507 if (foundIndex === -1) foundIndex = i 5508 if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex 5509 } else { 5510 foundIndex = -1 5511 } 5512 } 5513 return -1 5514 } 5515 5516 throw new TypeError('val must be string, number or Buffer') 5517 } 5518 5519 // `get` is deprecated 5520 Buffer.prototype.get = function get (offset) { 5521 console.log('.get() is deprecated. Access using array indexes instead.') 5522 return this.readUInt8(offset) 5523 } 5524 5525 // `set` is deprecated 5526 Buffer.prototype.set = function set (v, offset) { 5527 console.log('.set() is deprecated. Access using array indexes instead.') 5528 return this.writeUInt8(v, offset) 5529 } 5530 5531 function hexWrite (buf, string, offset, length) { 5532 offset = Number(offset) || 0 5533 var remaining = buf.length - offset 5534 if (!length) { 5535 length = remaining 5536 } else { 5537 length = Number(length) 5538 if (length > remaining) { 5539 length = remaining 5540 } 5541 } 5542 5543 // must be an even number of digits 5544 var strLen = string.length 5545 if (strLen % 2 !== 0) throw new Error('Invalid hex string') 5546 5547 if (length > strLen / 2) { 5548 length = strLen / 2 5549 } 5550 for (var i = 0; i < length; i++) { 5551 var parsed = parseInt(string.substr(i * 2, 2), 16) 5552 if (isNaN(parsed)) throw new Error('Invalid hex string') 5553 buf[offset + i] = parsed 5554 } 5555 return i 5556 } 5557 5558 function utf8Write (buf, string, offset, length) { 5559 return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) 5560 } 5561 5562 function asciiWrite (buf, string, offset, length) { 5563 return blitBuffer(asciiToBytes(string), buf, offset, length) 5564 } 5565 5566 function binaryWrite (buf, string, offset, length) { 5567 return asciiWrite(buf, string, offset, length) 5568 } 5569 5570 function base64Write (buf, string, offset, length) { 5571 return blitBuffer(base64ToBytes(string), buf, offset, length) 5572 } 5573 5574 function ucs2Write (buf, string, offset, length) { 5575 return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) 5576 } 5577 5578 Buffer.prototype.write = function write (string, offset, length, encoding) { 5579 // Buffer#write(string) 5580 if (offset === undefined) { 5581 encoding = 'utf8' 5582 length = this.length 5583 offset = 0 5584 // Buffer#write(string, encoding) 5585 } else if (length === undefined && typeof offset === 'string') { 5586 encoding = offset 5587 length = this.length 5588 offset = 0 5589 // Buffer#write(string, offset[, length][, encoding]) 5590 } else if (isFinite(offset)) { 5591 offset = offset | 0 5592 if (isFinite(length)) { 5593 length = length | 0 5594 if (encoding === undefined) encoding = 'utf8' 5595 } else { 5596 encoding = length 5597 length = undefined 5598 } 5599 // legacy write(string, encoding, offset, length) - remove in v0.13 5600 } else { 5601 var swap = encoding 5602 encoding = offset 5603 offset = length | 0 5604 length = swap 5605 } 5606 5607 var remaining = this.length - offset 5608 if (length === undefined || length > remaining) length = remaining 5609 5610 if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { 5611 throw new RangeError('attempt to write outside buffer bounds') 5612 } 5613 5614 if (!encoding) encoding = 'utf8' 5615 5616 var loweredCase = false 5617 for (;;) { 5618 switch (encoding) { 5619 case 'hex': 5620 return hexWrite(this, string, offset, length) 5621 5622 case 'utf8': 5623 case 'utf-8': 5624 return utf8Write(this, string, offset, length) 5625 5626 case 'ascii': 5627 return asciiWrite(this, string, offset, length) 5628 5629 case 'binary': 5630 return binaryWrite(this, string, offset, length) 5631 5632 case 'base64': 5633 // Warning: maxLength not taken into account in base64Write 5634 return base64Write(this, string, offset, length) 5635 5636 case 'ucs2': 5637 case 'ucs-2': 5638 case 'utf16le': 5639 case 'utf-16le': 5640 return ucs2Write(this, string, offset, length) 5641 5642 default: 5643 if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) 5644 encoding = ('' + encoding).toLowerCase() 5645 loweredCase = true 5646 } 5647 } 5648 } 5649 5650 Buffer.prototype.toJSON = function toJSON () { 5651 return { 5652 type: 'Buffer', 5653 data: Array.prototype.slice.call(this._arr || this, 0) 5654 } 5655 } 5656 5657 function base64Slice (buf, start, end) { 5658 if (start === 0 && end === buf.length) { 5659 return base64.fromByteArray(buf) 5660 } else { 5661 return base64.fromByteArray(buf.slice(start, end)) 5662 } 5663 } 5664 5665 function utf8Slice (buf, start, end) { 5666 end = Math.min(buf.length, end) 5667 var res = [] 5668 5669 var i = start 5670 while (i < end) { 5671 var firstByte = buf[i] 5672 var codePoint = null 5673 var bytesPerSequence = (firstByte > 0xEF) ? 4 5674 : (firstByte > 0xDF) ? 3 5675 : (firstByte > 0xBF) ? 2 5676 : 1 5677 5678 if (i + bytesPerSequence <= end) { 5679 var secondByte, thirdByte, fourthByte, tempCodePoint 5680 5681 switch (bytesPerSequence) { 5682 case 1: 5683 if (firstByte < 0x80) { 5684 codePoint = firstByte 5685 } 5686 break 5687 case 2: 5688 secondByte = buf[i + 1] 5689 if ((secondByte & 0xC0) === 0x80) { 5690 tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) 5691 if (tempCodePoint > 0x7F) { 5692 codePoint = tempCodePoint 5693 } 5694 } 5695 break 5696 case 3: 5697 secondByte = buf[i + 1] 5698 thirdByte = buf[i + 2] 5699 if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { 5700 tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) 5701 if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { 5702 codePoint = tempCodePoint 5703 } 5704 } 5705 break 5706 case 4: 5707 secondByte = buf[i + 1] 5708 thirdByte = buf[i + 2] 5709 fourthByte = buf[i + 3] 5710 if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { 5711 tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) 5712 if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { 5713 codePoint = tempCodePoint 5714 } 5715 } 5716 } 5717 } 5718 5719 if (codePoint === null) { 5720 // we did not generate a valid codePoint so insert a 5721 // replacement char (U+FFFD) and advance only 1 byte 5722 codePoint = 0xFFFD 5723 bytesPerSequence = 1 5724 } else if (codePoint > 0xFFFF) { 5725 // encode to utf16 (surrogate pair dance) 5726 codePoint -= 0x10000 5727 res.push(codePoint >>> 10 & 0x3FF | 0xD800) 5728 codePoint = 0xDC00 | codePoint & 0x3FF 5729 } 5730 5731 res.push(codePoint) 5732 i += bytesPerSequence 5733 } 5734 5735 return decodeCodePointsArray(res) 5736 } 5737 5738 // Based on http://stackoverflow.com/a/22747272/680742, the browser with 5739 // the lowest limit is Chrome, with 0x10000 args. 5740 // We go 1 magnitude less, for safety 5741 var MAX_ARGUMENTS_LENGTH = 0x1000 5742 5743 function decodeCodePointsArray (codePoints) { 5744 var len = codePoints.length 5745 if (len <= MAX_ARGUMENTS_LENGTH) { 5746 return String.fromCharCode.apply(String, codePoints) // avoid extra slice() 5747 } 5748 5749 // Decode in chunks to avoid "call stack size exceeded". 5750 var res = '' 5751 var i = 0 5752 while (i < len) { 5753 res += String.fromCharCode.apply( 5754 String, 5755 codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) 5756 ) 5757 } 5758 return res 5759 } 5760 5761 function asciiSlice (buf, start, end) { 5762 var ret = '' 5763 end = Math.min(buf.length, end) 5764 5765 for (var i = start; i < end; i++) { 5766 ret += String.fromCharCode(buf[i] & 0x7F) 5767 } 5768 return ret 5769 } 5770 5771 function binarySlice (buf, start, end) { 5772 var ret = '' 5773 end = Math.min(buf.length, end) 5774 5775 for (var i = start; i < end; i++) { 5776 ret += String.fromCharCode(buf[i]) 5777 } 5778 return ret 5779 } 5780 5781 function hexSlice (buf, start, end) { 5782 var len = buf.length 5783 5784 if (!start || start < 0) start = 0 5785 if (!end || end < 0 || end > len) end = len 5786 5787 var out = '' 5788 for (var i = start; i < end; i++) { 5789 out += toHex(buf[i]) 5790 } 5791 return out 5792 } 5793 5794 function utf16leSlice (buf, start, end) { 5795 var bytes = buf.slice(start, end) 5796 var res = '' 5797 for (var i = 0; i < bytes.length; i += 2) { 5798 res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256) 5799 } 5800 return res 5801 } 5802 5803 Buffer.prototype.slice = function slice (start, end) { 5804 var len = this.length 5805 start = ~~start 5806 end = end === undefined ? len : ~~end 5807 5808 if (start < 0) { 5809 start += len 5810 if (start < 0) start = 0 5811 } else if (start > len) { 5812 start = len 5813 } 5814 5815 if (end < 0) { 5816 end += len 5817 if (end < 0) end = 0 5818 } else if (end > len) { 5819 end = len 5820 } 5821 5822 if (end < start) end = start 5823 5824 var newBuf 5825 if (Buffer.TYPED_ARRAY_SUPPORT) { 5826 newBuf = Buffer._augment(this.subarray(start, end)) 5827 } else { 5828 var sliceLen = end - start 5829 newBuf = new Buffer(sliceLen, undefined) 5830 for (var i = 0; i < sliceLen; i++) { 5831 newBuf[i] = this[i + start] 5832 } 5833 } 5834 5835 if (newBuf.length) newBuf.parent = this.parent || this 5836 5837 return newBuf 5838 } 5839 5840 /* 5841 * Need to make sure that buffer isn't trying to write out of bounds. 5842 */ 5843 function checkOffset (offset, ext, length) { 5844 if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') 5845 if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') 5846 } 5847 5848 Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { 5849 offset = offset | 0 5850 byteLength = byteLength | 0 5851 if (!noAssert) checkOffset(offset, byteLength, this.length) 5852 5853 var val = this[offset] 5854 var mul = 1 5855 var i = 0 5856 while (++i < byteLength && (mul *= 0x100)) { 5857 val += this[offset + i] * mul 5858 } 5859 5860 return val 5861 } 5862 5863 Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { 5864 offset = offset | 0 5865 byteLength = byteLength | 0 5866 if (!noAssert) { 5867 checkOffset(offset, byteLength, this.length) 5868 } 5869 5870 var val = this[offset + --byteLength] 5871 var mul = 1 5872 while (byteLength > 0 && (mul *= 0x100)) { 5873 val += this[offset + --byteLength] * mul 5874 } 5875 5876 return val 5877 } 5878 5879 Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { 5880 if (!noAssert) checkOffset(offset, 1, this.length) 5881 return this[offset] 5882 } 5883 5884 Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { 5885 if (!noAssert) checkOffset(offset, 2, this.length) 5886 return this[offset] | (this[offset + 1] << 8) 5887 } 5888 5889 Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { 5890 if (!noAssert) checkOffset(offset, 2, this.length) 5891 return (this[offset] << 8) | this[offset + 1] 5892 } 5893 5894 Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { 5895 if (!noAssert) checkOffset(offset, 4, this.length) 5896 5897 return ((this[offset]) | 5898 (this[offset + 1] << 8) | 5899 (this[offset + 2] << 16)) + 5900 (this[offset + 3] * 0x1000000) 5901 } 5902 5903 Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { 5904 if (!noAssert) checkOffset(offset, 4, this.length) 5905 5906 return (this[offset] * 0x1000000) + 5907 ((this[offset + 1] << 16) | 5908 (this[offset + 2] << 8) | 5909 this[offset + 3]) 5910 } 5911 5912 Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { 5913 offset = offset | 0 5914 byteLength = byteLength | 0 5915 if (!noAssert) checkOffset(offset, byteLength, this.length) 5916 5917 var val = this[offset] 5918 var mul = 1 5919 var i = 0 5920 while (++i < byteLength && (mul *= 0x100)) { 5921 val += this[offset + i] * mul 5922 } 5923 mul *= 0x80 5924 5925 if (val >= mul) val -= Math.pow(2, 8 * byteLength) 5926 5927 return val 5928 } 5929 5930 Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { 5931 offset = offset | 0 5932 byteLength = byteLength | 0 5933 if (!noAssert) checkOffset(offset, byteLength, this.length) 5934 5935 var i = byteLength 5936 var mul = 1 5937 var val = this[offset + --i] 5938 while (i > 0 && (mul *= 0x100)) { 5939 val += this[offset + --i] * mul 5940 } 5941 mul *= 0x80 5942 5943 if (val >= mul) val -= Math.pow(2, 8 * byteLength) 5944 5945 return val 5946 } 5947 5948 Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { 5949 if (!noAssert) checkOffset(offset, 1, this.length) 5950 if (!(this[offset] & 0x80)) return (this[offset]) 5951 return ((0xff - this[offset] + 1) * -1) 5952 } 5953 5954 Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { 5955 if (!noAssert) checkOffset(offset, 2, this.length) 5956 var val = this[offset] | (this[offset + 1] << 8) 5957 return (val & 0x8000) ? val | 0xFFFF0000 : val 5958 } 5959 5960 Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { 5961 if (!noAssert) checkOffset(offset, 2, this.length) 5962 var val = this[offset + 1] | (this[offset] << 8) 5963 return (val & 0x8000) ? val | 0xFFFF0000 : val 5964 } 5965 5966 Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { 5967 if (!noAssert) checkOffset(offset, 4, this.length) 5968 5969 return (this[offset]) | 5970 (this[offset + 1] << 8) | 5971 (this[offset + 2] << 16) | 5972 (this[offset + 3] << 24) 5973 } 5974 5975 Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { 5976 if (!noAssert) checkOffset(offset, 4, this.length) 5977 5978 return (this[offset] << 24) | 5979 (this[offset + 1] << 16) | 5980 (this[offset + 2] << 8) | 5981 (this[offset + 3]) 5982 } 5983 5984 Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { 5985 if (!noAssert) checkOffset(offset, 4, this.length) 5986 return ieee754.read(this, offset, true, 23, 4) 5987 } 5988 5989 Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { 5990 if (!noAssert) checkOffset(offset, 4, this.length) 5991 return ieee754.read(this, offset, false, 23, 4) 5992 } 5993 5994 Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { 5995 if (!noAssert) checkOffset(offset, 8, this.length) 5996 return ieee754.read(this, offset, true, 52, 8) 5997 } 5998 5999 Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { 6000 if (!noAssert) checkOffset(offset, 8, this.length) 6001 return ieee754.read(this, offset, false, 52, 8) 6002 } 6003 6004 function checkInt (buf, value, offset, ext, max, min) { 6005 if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance') 6006 if (value > max || value < min) throw new RangeError('value is out of bounds') 6007 if (offset + ext > buf.length) throw new RangeError('index out of range') 6008 } 6009 6010 Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { 6011 value = +value 6012 offset = offset | 0 6013 byteLength = byteLength | 0 6014 if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) 6015 6016 var mul = 1 6017 var i = 0 6018 this[offset] = value & 0xFF 6019 while (++i < byteLength && (mul *= 0x100)) { 6020 this[offset + i] = (value / mul) & 0xFF 6021 } 6022 6023 return offset + byteLength 6024 } 6025 6026 Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { 6027 value = +value 6028 offset = offset | 0 6029 byteLength = byteLength | 0 6030 if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) 6031 6032 var i = byteLength - 1 6033 var mul = 1 6034 this[offset + i] = value & 0xFF 6035 while (--i >= 0 && (mul *= 0x100)) { 6036 this[offset + i] = (value / mul) & 0xFF 6037 } 6038 6039 return offset + byteLength 6040 } 6041 6042 Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { 6043 value = +value 6044 offset = offset | 0 6045 if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0) 6046 if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) 6047 this[offset] = value 6048 return offset + 1 6049 } 6050 6051 function objectWriteUInt16 (buf, value, offset, littleEndian) { 6052 if (value < 0) value = 0xffff + value + 1 6053 for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) { 6054 buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> 6055 (littleEndian ? i : 1 - i) * 8 6056 } 6057 } 6058 6059 Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { 6060 value = +value 6061 offset = offset | 0 6062 if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) 6063 if (Buffer.TYPED_ARRAY_SUPPORT) { 6064 this[offset] = value 6065 this[offset + 1] = (value >>> 8) 6066 } else { 6067 objectWriteUInt16(this, value, offset, true) 6068 } 6069 return offset + 2 6070 } 6071 6072 Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { 6073 value = +value 6074 offset = offset | 0 6075 if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) 6076 if (Buffer.TYPED_ARRAY_SUPPORT) { 6077 this[offset] = (value >>> 8) 6078 this[offset + 1] = value 6079 } else { 6080 objectWriteUInt16(this, value, offset, false) 6081 } 6082 return offset + 2 6083 } 6084 6085 function objectWriteUInt32 (buf, value, offset, littleEndian) { 6086 if (value < 0) value = 0xffffffff + value + 1 6087 for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) { 6088 buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff 6089 } 6090 } 6091 6092 Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { 6093 value = +value 6094 offset = offset | 0 6095 if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) 6096 if (Buffer.TYPED_ARRAY_SUPPORT) { 6097 this[offset + 3] = (value >>> 24) 6098 this[offset + 2] = (value >>> 16) 6099 this[offset + 1] = (value >>> 8) 6100 this[offset] = value 6101 } else { 6102 objectWriteUInt32(this, value, offset, true) 6103 } 6104 return offset + 4 6105 } 6106 6107 Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { 6108 value = +value 6109 offset = offset | 0 6110 if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) 6111 if (Buffer.TYPED_ARRAY_SUPPORT) { 6112 this[offset] = (value >>> 24) 6113 this[offset + 1] = (value >>> 16) 6114 this[offset + 2] = (value >>> 8) 6115 this[offset + 3] = value 6116 } else { 6117 objectWriteUInt32(this, value, offset, false) 6118 } 6119 return offset + 4 6120 } 6121 6122 Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { 6123 value = +value 6124 offset = offset | 0 6125 if (!noAssert) { 6126 var limit = Math.pow(2, 8 * byteLength - 1) 6127 6128 checkInt(this, value, offset, byteLength, limit - 1, -limit) 6129 } 6130 6131 var i = 0 6132 var mul = 1 6133 var sub = value < 0 ? 1 : 0 6134 this[offset] = value & 0xFF 6135 while (++i < byteLength && (mul *= 0x100)) { 6136 this[offset + i] = ((value / mul) >> 0) - sub & 0xFF 6137 } 6138 6139 return offset + byteLength 6140 } 6141 6142 Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { 6143 value = +value 6144 offset = offset | 0 6145 if (!noAssert) { 6146 var limit = Math.pow(2, 8 * byteLength - 1) 6147 6148 checkInt(this, value, offset, byteLength, limit - 1, -limit) 6149 } 6150 6151 var i = byteLength - 1 6152 var mul = 1 6153 var sub = value < 0 ? 1 : 0 6154 this[offset + i] = value & 0xFF 6155 while (--i >= 0 && (mul *= 0x100)) { 6156 this[offset + i] = ((value / mul) >> 0) - sub & 0xFF 6157 } 6158 6159 return offset + byteLength 6160 } 6161 6162 Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { 6163 value = +value 6164 offset = offset | 0 6165 if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80) 6166 if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) 6167 if (value < 0) value = 0xff + value + 1 6168 this[offset] = value 6169 return offset + 1 6170 } 6171 6172 Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { 6173 value = +value 6174 offset = offset | 0 6175 if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) 6176 if (Buffer.TYPED_ARRAY_SUPPORT) { 6177 this[offset] = value 6178 this[offset + 1] = (value >>> 8) 6179 } else { 6180 objectWriteUInt16(this, value, offset, true) 6181 } 6182 return offset + 2 6183 } 6184 6185 Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { 6186 value = +value 6187 offset = offset | 0 6188 if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) 6189 if (Buffer.TYPED_ARRAY_SUPPORT) { 6190 this[offset] = (value >>> 8) 6191 this[offset + 1] = value 6192 } else { 6193 objectWriteUInt16(this, value, offset, false) 6194 } 6195 return offset + 2 6196 } 6197 6198 Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { 6199 value = +value 6200 offset = offset | 0 6201 if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) 6202 if (Buffer.TYPED_ARRAY_SUPPORT) { 6203 this[offset] = value 6204 this[offset + 1] = (value >>> 8) 6205 this[offset + 2] = (value >>> 16) 6206 this[offset + 3] = (value >>> 24) 6207 } else { 6208 objectWriteUInt32(this, value, offset, true) 6209 } 6210 return offset + 4 6211 } 6212 6213 Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { 6214 value = +value 6215 offset = offset | 0 6216 if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) 6217 if (value < 0) value = 0xffffffff + value + 1 6218 if (Buffer.TYPED_ARRAY_SUPPORT) { 6219 this[offset] = (value >>> 24) 6220 this[offset + 1] = (value >>> 16) 6221 this[offset + 2] = (value >>> 8) 6222 this[offset + 3] = value 6223 } else { 6224 objectWriteUInt32(this, value, offset, false) 6225 } 6226 return offset + 4 6227 } 6228 6229 function checkIEEE754 (buf, value, offset, ext, max, min) { 6230 if (value > max || value < min) throw new RangeError('value is out of bounds') 6231 if (offset + ext > buf.length) throw new RangeError('index out of range') 6232 if (offset < 0) throw new RangeError('index out of range') 6233 } 6234 6235 function writeFloat (buf, value, offset, littleEndian, noAssert) { 6236 if (!noAssert) { 6237 checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38) 6238 } 6239 ieee754.write(buf, value, offset, littleEndian, 23, 4) 6240 return offset + 4 6241 } 6242 6243 Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { 6244 return writeFloat(this, value, offset, true, noAssert) 6245 } 6246 6247 Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { 6248 return writeFloat(this, value, offset, false, noAssert) 6249 } 6250 6251 function writeDouble (buf, value, offset, littleEndian, noAssert) { 6252 if (!noAssert) { 6253 checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308) 6254 } 6255 ieee754.write(buf, value, offset, littleEndian, 52, 8) 6256 return offset + 8 6257 } 6258 6259 Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { 6260 return writeDouble(this, value, offset, true, noAssert) 6261 } 6262 6263 Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { 6264 return writeDouble(this, value, offset, false, noAssert) 6265 } 6266 6267 // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) 6268 Buffer.prototype.copy = function copy (target, targetStart, start, end) { 6269 if (!start) start = 0 6270 if (!end && end !== 0) end = this.length 6271 if (targetStart >= target.length) targetStart = target.length 6272 if (!targetStart) targetStart = 0 6273 if (end > 0 && end < start) end = start 6274 6275 // Copy 0 bytes; we're done 6276 if (end === start) return 0 6277 if (target.length === 0 || this.length === 0) return 0 6278 6279 // Fatal error conditions 6280 if (targetStart < 0) { 6281 throw new RangeError('targetStart out of bounds') 6282 } 6283 if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') 6284 if (end < 0) throw new RangeError('sourceEnd out of bounds') 6285 6286 // Are we oob? 6287 if (end > this.length) end = this.length 6288 if (target.length - targetStart < end - start) { 6289 end = target.length - targetStart + start 6290 } 6291 6292 var len = end - start 6293 var i 6294 6295 if (this === target && start < targetStart && targetStart < end) { 6296 // descending copy from end 6297 for (i = len - 1; i >= 0; i--) { 6298 target[i + targetStart] = this[i + start] 6299 } 6300 } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { 6301 // ascending copy from start 6302 for (i = 0; i < len; i++) { 6303 target[i + targetStart] = this[i + start] 6304 } 6305 } else { 6306 target._set(this.subarray(start, start + len), targetStart) 6307 } 6308 6309 return len 6310 } 6311 6312 // fill(value, start=0, end=buffer.length) 6313 Buffer.prototype.fill = function fill (value, start, end) { 6314 if (!value) value = 0 6315 if (!start) start = 0 6316 if (!end) end = this.length 6317 6318 if (end < start) throw new RangeError('end < start') 6319 6320 // Fill 0 bytes; we're done 6321 if (end === start) return 6322 if (this.length === 0) return 6323 6324 if (start < 0 || start >= this.length) throw new RangeError('start out of bounds') 6325 if (end < 0 || end > this.length) throw new RangeError('end out of bounds') 6326 6327 var i 6328 if (typeof value === 'number') { 6329 for (i = start; i < end; i++) { 6330 this[i] = value 6331 } 6332 } else { 6333 var bytes = utf8ToBytes(value.toString()) 6334 var len = bytes.length 6335 for (i = start; i < end; i++) { 6336 this[i] = bytes[i % len] 6337 } 6338 } 6339 6340 return this 6341 } 6342 6343 /** 6344 * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance. 6345 * Added in Node 0.12. Only available in browsers that support ArrayBuffer. 6346 */ 6347 Buffer.prototype.toArrayBuffer = function toArrayBuffer () { 6348 if (typeof Uint8Array !== 'undefined') { 6349 if (Buffer.TYPED_ARRAY_SUPPORT) { 6350 return (new Buffer(this)).buffer 6351 } else { 6352 var buf = new Uint8Array(this.length) 6353 for (var i = 0, len = buf.length; i < len; i += 1) { 6354 buf[i] = this[i] 6355 } 6356 return buf.buffer 6357 } 6358 } else { 6359 throw new TypeError('Buffer.toArrayBuffer not supported in this browser') 6360 } 6361 } 6362 6363 // HELPER FUNCTIONS 6364 // ================ 6365 6366 var BP = Buffer.prototype 6367 6368 /** 6369 * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods 6370 */ 6371 Buffer._augment = function _augment (arr) { 6372 arr.constructor = Buffer 6373 arr._isBuffer = true 6374 6375 // save reference to original Uint8Array set method before overwriting 6376 arr._set = arr.set 6377 6378 // deprecated 6379 arr.get = BP.get 6380 arr.set = BP.set 6381 6382 arr.write = BP.write 6383 arr.toString = BP.toString 6384 arr.toLocaleString = BP.toString 6385 arr.toJSON = BP.toJSON 6386 arr.equals = BP.equals 6387 arr.compare = BP.compare 6388 arr.indexOf = BP.indexOf 6389 arr.copy = BP.copy 6390 arr.slice = BP.slice 6391 arr.readUIntLE = BP.readUIntLE 6392 arr.readUIntBE = BP.readUIntBE 6393 arr.readUInt8 = BP.readUInt8 6394 arr.readUInt16LE = BP.readUInt16LE 6395 arr.readUInt16BE = BP.readUInt16BE 6396 arr.readUInt32LE = BP.readUInt32LE 6397 arr.readUInt32BE = BP.readUInt32BE 6398 arr.readIntLE = BP.readIntLE 6399 arr.readIntBE = BP.readIntBE 6400 arr.readInt8 = BP.readInt8 6401 arr.readInt16LE = BP.readInt16LE 6402 arr.readInt16BE = BP.readInt16BE 6403 arr.readInt32LE = BP.readInt32LE 6404 arr.readInt32BE = BP.readInt32BE 6405 arr.readFloatLE = BP.readFloatLE 6406 arr.readFloatBE = BP.readFloatBE 6407 arr.readDoubleLE = BP.readDoubleLE 6408 arr.readDoubleBE = BP.readDoubleBE 6409 arr.writeUInt8 = BP.writeUInt8 6410 arr.writeUIntLE = BP.writeUIntLE 6411 arr.writeUIntBE = BP.writeUIntBE 6412 arr.writeUInt16LE = BP.writeUInt16LE 6413 arr.writeUInt16BE = BP.writeUInt16BE 6414 arr.writeUInt32LE = BP.writeUInt32LE 6415 arr.writeUInt32BE = BP.writeUInt32BE 6416 arr.writeIntLE = BP.writeIntLE 6417 arr.writeIntBE = BP.writeIntBE 6418 arr.writeInt8 = BP.writeInt8 6419 arr.writeInt16LE = BP.writeInt16LE 6420 arr.writeInt16BE = BP.writeInt16BE 6421 arr.writeInt32LE = BP.writeInt32LE 6422 arr.writeInt32BE = BP.writeInt32BE 6423 arr.writeFloatLE = BP.writeFloatLE 6424 arr.writeFloatBE = BP.writeFloatBE 6425 arr.writeDoubleLE = BP.writeDoubleLE 6426 arr.writeDoubleBE = BP.writeDoubleBE 6427 arr.fill = BP.fill 6428 arr.inspect = BP.inspect 6429 arr.toArrayBuffer = BP.toArrayBuffer 6430 6431 return arr 6432 } 6433 6434 var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g 6435 6436 function base64clean (str) { 6437 // Node strips out invalid characters like \n and \t from the string, base64-js does not 6438 str = stringtrim(str).replace(INVALID_BASE64_RE, '') 6439 // Node converts strings with length < 2 to '' 6440 if (str.length < 2) return '' 6441 // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not 6442 while (str.length % 4 !== 0) { 6443 str = str + '=' 6444 } 6445 return str 6446 } 6447 6448 function stringtrim (str) { 6449 if (str.trim) return str.trim() 6450 return str.replace(/^\s+|\s+$/g, '') 6451 } 6452 6453 function toHex (n) { 6454 if (n < 16) return '0' + n.toString(16) 6455 return n.toString(16) 6456 } 6457 6458 function utf8ToBytes (string, units) { 6459 units = units || Infinity 6460 var codePoint 6461 var length = string.length 6462 var leadSurrogate = null 6463 var bytes = [] 6464 6465 for (var i = 0; i < length; i++) { 6466 codePoint = string.charCodeAt(i) 6467 6468 // is surrogate component 6469 if (codePoint > 0xD7FF && codePoint < 0xE000) { 6470 // last char was a lead 6471 if (!leadSurrogate) { 6472 // no lead yet 6473 if (codePoint > 0xDBFF) { 6474 // unexpected trail 6475 if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) 6476 continue 6477 } else if (i + 1 === length) { 6478 // unpaired lead 6479 if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) 6480 continue 6481 } 6482 6483 // valid lead 6484 leadSurrogate = codePoint 6485 6486 continue 6487 } 6488 6489 // 2 leads in a row 6490 if (codePoint < 0xDC00) { 6491 if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) 6492 leadSurrogate = codePoint 6493 continue 6494 } 6495 6496 // valid surrogate pair 6497 codePoint = leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00 | 0x10000 6498 } else if (leadSurrogate) { 6499 // valid bmp char, but last char was a lead 6500 if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) 6501 } 6502 6503 leadSurrogate = null 6504 6505 // encode utf8 6506 if (codePoint < 0x80) { 6507 if ((units -= 1) < 0) break 6508 bytes.push(codePoint) 6509 } else if (codePoint < 0x800) { 6510 if ((units -= 2) < 0) break 6511 bytes.push( 6512 codePoint >> 0x6 | 0xC0, 6513 codePoint & 0x3F | 0x80 6514 ) 6515 } else if (codePoint < 0x10000) { 6516 if ((units -= 3) < 0) break 6517 bytes.push( 6518 codePoint >> 0xC | 0xE0, 6519 codePoint >> 0x6 & 0x3F | 0x80, 6520 codePoint & 0x3F | 0x80 6521 ) 6522 } else if (codePoint < 0x110000) { 6523 if ((units -= 4) < 0) break 6524 bytes.push( 6525 codePoint >> 0x12 | 0xF0, 6526 codePoint >> 0xC & 0x3F | 0x80, 6527 codePoint >> 0x6 & 0x3F | 0x80, 6528 codePoint & 0x3F | 0x80 6529 ) 6530 } else { 6531 throw new Error('Invalid code point') 6532 } 6533 } 6534 6535 return bytes 6536 } 6537 6538 function asciiToBytes (str) { 6539 var byteArray = [] 6540 for (var i = 0; i < str.length; i++) { 6541 // Node's code seems to be doing this and not & 0x7F.. 6542 byteArray.push(str.charCodeAt(i) & 0xFF) 6543 } 6544 return byteArray 6545 } 6546 6547 function utf16leToBytes (str, units) { 6548 var c, hi, lo 6549 var byteArray = [] 6550 for (var i = 0; i < str.length; i++) { 6551 if ((units -= 2) < 0) break 6552 6553 c = str.charCodeAt(i) 6554 hi = c >> 8 6555 lo = c % 256 6556 byteArray.push(lo) 6557 byteArray.push(hi) 6558 } 6559 6560 return byteArray 6561 } 6562 6563 function base64ToBytes (str) { 6564 return base64.toByteArray(base64clean(str)) 6565 } 6566 6567 function blitBuffer (src, dst, offset, length) { 6568 for (var i = 0; i < length; i++) { 6569 if ((i + offset >= dst.length) || (i >= src.length)) break 6570 dst[i + offset] = src[i] 6571 } 6572 return i 6573 } 6574 6575 },{"base64-js":16,"ieee754":17,"is-array":18}],16:[function(require,module,exports){ 6576 var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'; 6577 6578 ;(function (exports) { 6579 'use strict'; 6580 6581 var Arr = (typeof Uint8Array !== 'undefined') 6582 ? Uint8Array 6583 : Array 6584 6585 var PLUS = '+'.charCodeAt(0) 6586 var SLASH = '/'.charCodeAt(0) 6587 var NUMBER = '0'.charCodeAt(0) 6588 var LOWER = 'a'.charCodeAt(0) 6589 var UPPER = 'A'.charCodeAt(0) 6590 var PLUS_URL_SAFE = '-'.charCodeAt(0) 6591 var SLASH_URL_SAFE = '_'.charCodeAt(0) 6592 6593 function decode (elt) { 6594 var code = elt.charCodeAt(0) 6595 if (code === PLUS || 6596 code === PLUS_URL_SAFE) 6597 return 62 // '+' 6598 if (code === SLASH || 6599 code === SLASH_URL_SAFE) 6600 return 63 // '/' 6601 if (code < NUMBER) 6602 return -1 //no match 6603 if (code < NUMBER + 10) 6604 return code - NUMBER + 26 + 26 6605 if (code < UPPER + 26) 6606 return code - UPPER 6607 if (code < LOWER + 26) 6608 return code - LOWER + 26 6609 } 6610 6611 function b64ToByteArray (b64) { 6612 var i, j, l, tmp, placeHolders, arr 6613 6614 if (b64.length % 4 > 0) { 6615 throw new Error('Invalid string. Length must be a multiple of 4') 6616 } 6617 6618 // the number of equal signs (place holders) 6619 // if there are two placeholders, than the two characters before it 6620 // represent one byte 6621 // if there is only one, then the three characters before it represent 2 bytes 6622 // this is just a cheap hack to not do indexOf twice 6623 var len = b64.length 6624 placeHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0 6625 6626 // base64 is 4/3 + up to two characters of the original data 6627 arr = new Arr(b64.length * 3 / 4 - placeHolders) 6628 6629 // if there are placeholders, only get up to the last complete 4 chars 6630 l = placeHolders > 0 ? b64.length - 4 : b64.length 6631 6632 var L = 0 6633 6634 function push (v) { 6635 arr[L++] = v 6636 } 6637 6638 for (i = 0, j = 0; i < l; i += 4, j += 3) { 6639 tmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3)) 6640 push((tmp & 0xFF0000) >> 16) 6641 push((tmp & 0xFF00) >> 8) 6642 push(tmp & 0xFF) 6643 } 6644 6645 if (placeHolders === 2) { 6646 tmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4) 6647 push(tmp & 0xFF) 6648 } else if (placeHolders === 1) { 6649 tmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2) 6650 push((tmp >> 8) & 0xFF) 6651 push(tmp & 0xFF) 6652 } 6653 6654 return arr 6655 } 6656 6657 function uint8ToBase64 (uint8) { 6658 var i, 6659 extraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes 6660 output = "", 6661 temp, length 6662 6663 function encode (num) { 6664 return lookup.charAt(num) 6665 } 6666 6667 function tripletToBase64 (num) { 6668 return encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F) 6669 } 6670 6671 // go through the array every three bytes, we'll deal with trailing stuff later 6672 for (i = 0, length = uint8.length - extraBytes; i < length; i += 3) { 6673 temp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]) 6674 output += tripletToBase64(temp) 6675 } 6676 6677 // pad the end with zeros, but make sure to not forget the extra bytes 6678 switch (extraBytes) { 6679 case 1: 6680 temp = uint8[uint8.length - 1] 6681 output += encode(temp >> 2) 6682 output += encode((temp << 4) & 0x3F) 6683 output += '==' 6684 break 6685 case 2: 6686 temp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1]) 6687 output += encode(temp >> 10) 6688 output += encode((temp >> 4) & 0x3F) 6689 output += encode((temp << 2) & 0x3F) 6690 output += '=' 6691 break 6692 } 6693 6694 return output 6695 } 6696 6697 exports.toByteArray = b64ToByteArray 6698 exports.fromByteArray = uint8ToBase64 6699 }(typeof exports === 'undefined' ? (this.base64js = {}) : exports)) 6700 6701 },{}],17:[function(require,module,exports){ 6702 exports.read = function (buffer, offset, isLE, mLen, nBytes) { 6703 var e, m 6704 var eLen = nBytes * 8 - mLen - 1 6705 var eMax = (1 << eLen) - 1 6706 var eBias = eMax >> 1 6707 var nBits = -7 6708 var i = isLE ? (nBytes - 1) : 0 6709 var d = isLE ? -1 : 1 6710 var s = buffer[offset + i] 6711 6712 i += d 6713 6714 e = s & ((1 << (-nBits)) - 1) 6715 s >>= (-nBits) 6716 nBits += eLen 6717 for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} 6718 6719 m = e & ((1 << (-nBits)) - 1) 6720 e >>= (-nBits) 6721 nBits += mLen 6722 for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} 6723 6724 if (e === 0) { 6725 e = 1 - eBias 6726 } else if (e === eMax) { 6727 return m ? NaN : ((s ? -1 : 1) * Infinity) 6728 } else { 6729 m = m + Math.pow(2, mLen) 6730 e = e - eBias 6731 } 6732 return (s ? -1 : 1) * m * Math.pow(2, e - mLen) 6733 } 6734 6735 exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { 6736 var e, m, c 6737 var eLen = nBytes * 8 - mLen - 1 6738 var eMax = (1 << eLen) - 1 6739 var eBias = eMax >> 1 6740 var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0) 6741 var i = isLE ? 0 : (nBytes - 1) 6742 var d = isLE ? 1 : -1 6743 var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0 6744 6745 value = Math.abs(value) 6746 6747 if (isNaN(value) || value === Infinity) { 6748 m = isNaN(value) ? 1 : 0 6749 e = eMax 6750 } else { 6751 e = Math.floor(Math.log(value) / Math.LN2) 6752 if (value * (c = Math.pow(2, -e)) < 1) { 6753 e-- 6754 c *= 2 6755 } 6756 if (e + eBias >= 1) { 6757 value += rt / c 6758 } else { 6759 value += rt * Math.pow(2, 1 - eBias) 6760 } 6761 if (value * c >= 2) { 6762 e++ 6763 c /= 2 6764 } 6765 6766 if (e + eBias >= eMax) { 6767 m = 0 6768 e = eMax 6769 } else if (e + eBias >= 1) { 6770 m = (value * c - 1) * Math.pow(2, mLen) 6771 e = e + eBias 6772 } else { 6773 m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen) 6774 e = 0 6775 } 6776 } 6777 6778 for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} 6779 6780 e = (e << mLen) | m 6781 eLen += mLen 6782 for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} 6783 6784 buffer[offset + i - d] |= s * 128 6785 } 6786 6787 },{}],18:[function(require,module,exports){ 6788 6789 /** 6790 * isArray 6791 */ 6792 6793 var isArray = Array.isArray; 6794 6795 /** 6796 * toString 6797 */ 6798 6799 var str = Object.prototype.toString; 6800 6801 /** 6802 * Whether or not the given `val` 6803 * is an array. 6804 * 6805 * example: 6806 * 6807 * isArray([]); 6808 * // > true 6809 * isArray(arguments); 6810 * // > false 6811 * isArray(''); 6812 * // > false 6813 * 6814 * @param {mixed} val 6815 * @return {bool} 6816 */ 6817 6818 module.exports = isArray || function (val) { 6819 return !! val && '[object Array]' == str.call(val); 6820 }; 6821 6822 },{}],19:[function(require,module,exports){ 6823 /* jshint node: true */ 6824 (function () { 6825 "use strict"; 6826 6827 function CookieAccessInfo(domain, path, secure, script) { 6828 if (this instanceof CookieAccessInfo) { 6829 this.domain = domain || undefined; 6830 this.path = path || "/"; 6831 this.secure = !!secure; 6832 this.script = !!script; 6833 return this; 6834 } 6835 return new CookieAccessInfo(domain, path, secure, script); 6836 } 6837 exports.CookieAccessInfo = CookieAccessInfo; 6838 6839 function Cookie(cookiestr, request_domain, request_path) { 6840 if (cookiestr instanceof Cookie) { 6841 return cookiestr; 6842 } 6843 if (this instanceof Cookie) { 6844 this.name = null; 6845 this.value = null; 6846 this.expiration_date = Infinity; 6847 this.path = String(request_path || "/"); 6848 this.explicit_path = false; 6849 this.domain = request_domain || null; 6850 this.explicit_domain = false; 6851 this.secure = false; //how to define default? 6852 this.noscript = false; //httponly 6853 if (cookiestr) { 6854 this.parse(cookiestr, request_domain, request_path); 6855 } 6856 return this; 6857 } 6858 return new Cookie(cookiestr, request_domain, request_path); 6859 } 6860 exports.Cookie = Cookie; 6861 6862 Cookie.prototype.toString = function toString() { 6863 var str = [this.name + "=" + this.value]; 6864 if (this.expiration_date !== Infinity) { 6865 str.push("expires=" + (new Date(this.expiration_date)).toGMTString()); 6866 } 6867 if (this.domain) { 6868 str.push("domain=" + this.domain); 6869 } 6870 if (this.path) { 6871 str.push("path=" + this.path); 6872 } 6873 if (this.secure) { 6874 str.push("secure"); 6875 } 6876 if (this.noscript) { 6877 str.push("httponly"); 6878 } 6879 return str.join("; "); 6880 }; 6881 6882 Cookie.prototype.toValueString = function toValueString() { 6883 return this.name + "=" + this.value; 6884 }; 6885 6886 var cookie_str_splitter = /[:](?=\s*[a-zA-Z0-9_\-]+\s*[=])/g; 6887 Cookie.prototype.parse = function parse(str, request_domain, request_path) { 6888 if (this instanceof Cookie) { 6889 var parts = str.split(";").filter(function (value) { 6890 return !!value; 6891 }), 6892 pair = parts[0].match(/([^=]+)=([\s\S]*)/), 6893 key = pair[1], 6894 value = pair[2], 6895 i; 6896 this.name = key; 6897 this.value = value; 6898 6899 for (i = 1; i < parts.length; i += 1) { 6900 pair = parts[i].match(/([^=]+)(?:=([\s\S]*))?/); 6901 key = pair[1].trim().toLowerCase(); 6902 value = pair[2]; 6903 switch (key) { 6904 case "httponly": 6905 this.noscript = true; 6906 break; 6907 case "expires": 6908 this.expiration_date = value ? 6909 Number(Date.parse(value)) : 6910 Infinity; 6911 break; 6912 case "path": 6913 this.path = value ? 6914 value.trim() : 6915 ""; 6916 this.explicit_path = true; 6917 break; 6918 case "domain": 6919 this.domain = value ? 6920 value.trim() : 6921 ""; 6922 this.explicit_domain = !!this.domain; 6923 break; 6924 case "secure": 6925 this.secure = true; 6926 break; 6927 } 6928 } 6929 6930 if (!this.explicit_path) { 6931 this.path = request_path || "/"; 6932 } 6933 if (!this.explicit_domain) { 6934 this.domain = request_domain; 6935 } 6936 6937 return this; 6938 } 6939 return new Cookie().parse(str, request_domain, request_path); 6940 }; 6941 6942 Cookie.prototype.matches = function matches(access_info) { 6943 if (this.noscript && access_info.script || 6944 this.secure && !access_info.secure || 6945 !this.collidesWith(access_info)) { 6946 return false; 6947 } 6948 return true; 6949 }; 6950 6951 Cookie.prototype.collidesWith = function collidesWith(access_info) { 6952 if ((this.path && !access_info.path) || (this.domain && !access_info.domain)) { 6953 return false; 6954 } 6955 if (this.path && access_info.path.indexOf(this.path) !== 0) { 6956 return false; 6957 } 6958 if (this.explicit_path && access_info.path.indexOf( this.path ) !== 0) { 6959 return false; 6960 } 6961 var access_domain = access_info.domain && access_info.domain.replace(/^[\.]/,''); 6962 var cookie_domain = this.domain && this.domain.replace(/^[\.]/,''); 6963 if (cookie_domain === access_domain) { 6964 return true; 6965 } 6966 if (cookie_domain) { 6967 if (!this.explicit_domain) { 6968 return false; // we already checked if the domains were exactly the same 6969 } 6970 var wildcard = access_domain.indexOf(cookie_domain); 6971 if (wildcard === -1 || wildcard !== access_domain.length - cookie_domain.length) { 6972 return false; 6973 } 6974 return true; 6975 } 6976 return true; 6977 }; 6978 6979 function CookieJar() { 6980 var cookies, cookies_list, collidable_cookie; 6981 if (this instanceof CookieJar) { 6982 cookies = Object.create(null); //name: [Cookie] 6983 6984 this.setCookie = function setCookie(cookie, request_domain, request_path) { 6985 var remove, i; 6986 cookie = new Cookie(cookie, request_domain, request_path); 6987 //Delete the cookie if the set is past the current time 6988 remove = cookie.expiration_date <= Date.now(); 6989 if (cookies[cookie.name] !== undefined) { 6990 cookies_list = cookies[cookie.name]; 6991 for (i = 0; i < cookies_list.length; i += 1) { 6992 collidable_cookie = cookies_list[i]; 6993 if (collidable_cookie.collidesWith(cookie)) { 6994 if (remove) { 6995 cookies_list.splice(i, 1); 6996 if (cookies_list.length === 0) { 6997 delete cookies[cookie.name]; 6998 } 6999 return false; 7000 } 7001 cookies_list[i] = cookie; 7002 return cookie; 7003 } 7004 } 7005 if (remove) { 7006 return false; 7007 } 7008 cookies_list.push(cookie); 7009 return cookie; 7010 } 7011 if (remove) { 7012 return false; 7013 } 7014 cookies[cookie.name] = [cookie]; 7015 return cookies[cookie.name]; 7016 }; 7017 //returns a cookie 7018 this.getCookie = function getCookie(cookie_name, access_info) { 7019 var cookie, i; 7020 cookies_list = cookies[cookie_name]; 7021 if (!cookies_list) { 7022 return; 7023 } 7024 for (i = 0; i < cookies_list.length; i += 1) { 7025 cookie = cookies_list[i]; 7026 if (cookie.expiration_date <= Date.now()) { 7027 if (cookies_list.length === 0) { 7028 delete cookies[cookie.name]; 7029 } 7030 continue; 7031 } 7032 7033 if (cookie.matches(access_info)) { 7034 return cookie; 7035 } 7036 } 7037 }; 7038 //returns a list of cookies 7039 this.getCookies = function getCookies(access_info) { 7040 var matches = [], cookie_name, cookie; 7041 for (cookie_name in cookies) { 7042 cookie = this.getCookie(cookie_name, access_info); 7043 if (cookie) { 7044 matches.push(cookie); 7045 } 7046 } 7047 matches.toString = function toString() { 7048 return matches.join(":"); 7049 }; 7050 matches.toValueString = function toValueString() { 7051 return matches.map(function (c) { 7052 return c.toValueString(); 7053 }).join(';'); 7054 }; 7055 return matches; 7056 }; 7057 7058 return this; 7059 } 7060 return new CookieJar(); 7061 } 7062 exports.CookieJar = CookieJar; 7063 7064 //returns list of cookies that were set correctly. Cookies that are expired and removed are not returned. 7065 CookieJar.prototype.setCookies = function setCookies(cookies, request_domain, request_path) { 7066 cookies = Array.isArray(cookies) ? 7067 cookies : 7068 cookies.split(cookie_str_splitter); 7069 var successful = [], 7070 i, 7071 cookie; 7072 cookies = cookies.map(function(item){ 7073 return new Cookie(item, request_domain, request_path); 7074 }); 7075 for (i = 0; i < cookies.length; i += 1) { 7076 cookie = cookies[i]; 7077 if (this.setCookie(cookie, request_domain, request_path)) { 7078 successful.push(cookie); 7079 } 7080 } 7081 return successful; 7082 }; 7083 }()); 7084 7085 },{}],20:[function(require,module,exports){ 7086 'use strict'; 7087 7088 7089 var yaml = require('./lib/js-yaml.js'); 7090 7091 7092 module.exports = yaml; 7093 7094 },{"./lib/js-yaml.js":21}],21:[function(require,module,exports){ 7095 'use strict'; 7096 7097 7098 var loader = require('./js-yaml/loader'); 7099 var dumper = require('./js-yaml/dumper'); 7100 7101 7102 function deprecated(name) { 7103 return function () { 7104 throw new Error('Function ' + name + ' is deprecated and cannot be used.'); 7105 }; 7106 } 7107 7108 7109 module.exports.Type = require('./js-yaml/type'); 7110 module.exports.Schema = require('./js-yaml/schema'); 7111 module.exports.FAILSAFE_SCHEMA = require('./js-yaml/schema/failsafe'); 7112 module.exports.JSON_SCHEMA = require('./js-yaml/schema/json'); 7113 module.exports.CORE_SCHEMA = require('./js-yaml/schema/core'); 7114 module.exports.DEFAULT_SAFE_SCHEMA = require('./js-yaml/schema/default_safe'); 7115 module.exports.DEFAULT_FULL_SCHEMA = require('./js-yaml/schema/default_full'); 7116 module.exports.load = loader.load; 7117 module.exports.loadAll = loader.loadAll; 7118 module.exports.safeLoad = loader.safeLoad; 7119 module.exports.safeLoadAll = loader.safeLoadAll; 7120 module.exports.dump = dumper.dump; 7121 module.exports.safeDump = dumper.safeDump; 7122 module.exports.YAMLException = require('./js-yaml/exception'); 7123 7124 // Deprecated schema names from JS-YAML 2.0.x 7125 module.exports.MINIMAL_SCHEMA = require('./js-yaml/schema/failsafe'); 7126 module.exports.SAFE_SCHEMA = require('./js-yaml/schema/default_safe'); 7127 module.exports.DEFAULT_SCHEMA = require('./js-yaml/schema/default_full'); 7128 7129 // Deprecated functions from JS-YAML 1.x.x 7130 module.exports.scan = deprecated('scan'); 7131 module.exports.parse = deprecated('parse'); 7132 module.exports.compose = deprecated('compose'); 7133 module.exports.addConstructor = deprecated('addConstructor'); 7134 7135 },{"./js-yaml/dumper":23,"./js-yaml/exception":24,"./js-yaml/loader":25,"./js-yaml/schema":27,"./js-yaml/schema/core":28,"./js-yaml/schema/default_full":29,"./js-yaml/schema/default_safe":30,"./js-yaml/schema/failsafe":31,"./js-yaml/schema/json":32,"./js-yaml/type":33}],22:[function(require,module,exports){ 7136 'use strict'; 7137 7138 7139 function isNothing(subject) { 7140 return (typeof subject === 'undefined') || (null === subject); 7141 } 7142 7143 7144 function isObject(subject) { 7145 return (typeof subject === 'object') && (null !== subject); 7146 } 7147 7148 7149 function toArray(sequence) { 7150 if (Array.isArray(sequence)) { 7151 return sequence; 7152 } else if (isNothing(sequence)) { 7153 return []; 7154 } 7155 return [ sequence ]; 7156 } 7157 7158 7159 function extend(target, source) { 7160 var index, length, key, sourceKeys; 7161 7162 if (source) { 7163 sourceKeys = Object.keys(source); 7164 7165 for (index = 0, length = sourceKeys.length; index < length; index += 1) { 7166 key = sourceKeys[index]; 7167 target[key] = source[key]; 7168 } 7169 } 7170 7171 return target; 7172 } 7173 7174 7175 function repeat(string, count) { 7176 var result = '', cycle; 7177 7178 for (cycle = 0; cycle < count; cycle += 1) { 7179 result += string; 7180 } 7181 7182 return result; 7183 } 7184 7185 7186 function isNegativeZero(number) { 7187 return (0 === number) && (Number.NEGATIVE_INFINITY === 1 / number); 7188 } 7189 7190 7191 module.exports.isNothing = isNothing; 7192 module.exports.isObject = isObject; 7193 module.exports.toArray = toArray; 7194 module.exports.repeat = repeat; 7195 module.exports.isNegativeZero = isNegativeZero; 7196 module.exports.extend = extend; 7197 7198 },{}],23:[function(require,module,exports){ 7199 'use strict'; 7200 7201 /*eslint-disable no-use-before-define*/ 7202 7203 var common = require('./common'); 7204 var YAMLException = require('./exception'); 7205 var DEFAULT_FULL_SCHEMA = require('./schema/default_full'); 7206 var DEFAULT_SAFE_SCHEMA = require('./schema/default_safe'); 7207 7208 var _toString = Object.prototype.toString; 7209 var _hasOwnProperty = Object.prototype.hasOwnProperty; 7210 7211 var CHAR_TAB = 0x09; /* Tab */ 7212 var CHAR_LINE_FEED = 0x0A; /* LF */ 7213 var CHAR_CARRIAGE_RETURN = 0x0D; /* CR */ 7214 var CHAR_SPACE = 0x20; /* Space */ 7215 var CHAR_EXCLAMATION = 0x21; /* ! */ 7216 var CHAR_DOUBLE_QUOTE = 0x22; /* " */ 7217 var CHAR_SHARP = 0x23; /* # */ 7218 var CHAR_PERCENT = 0x25; /* % */ 7219 var CHAR_AMPERSAND = 0x26; /* & */ 7220 var CHAR_SINGLE_QUOTE = 0x27; /* ' */ 7221 var CHAR_ASTERISK = 0x2A; /* * */ 7222 var CHAR_COMMA = 0x2C; /* , */ 7223 var CHAR_MINUS = 0x2D; /* - */ 7224 var CHAR_COLON = 0x3A; /* : */ 7225 var CHAR_GREATER_THAN = 0x3E; /* > */ 7226 var CHAR_QUESTION = 0x3F; /* ? */ 7227 var CHAR_COMMERCIAL_AT = 0x40; /* @ */ 7228 var CHAR_LEFT_SQUARE_BRACKET = 0x5B; /* [ */ 7229 var CHAR_RIGHT_SQUARE_BRACKET = 0x5D; /* ] */ 7230 var CHAR_GRAVE_ACCENT = 0x60; /* ` */ 7231 var CHAR_LEFT_CURLY_BRACKET = 0x7B; /* { */ 7232 var CHAR_VERTICAL_LINE = 0x7C; /* | */ 7233 var CHAR_RIGHT_CURLY_BRACKET = 0x7D; /* } */ 7234 7235 var ESCAPE_SEQUENCES = {}; 7236 7237 ESCAPE_SEQUENCES[0x00] = '\\0'; 7238 ESCAPE_SEQUENCES[0x07] = '\\a'; 7239 ESCAPE_SEQUENCES[0x08] = '\\b'; 7240 ESCAPE_SEQUENCES[0x09] = '\\t'; 7241 ESCAPE_SEQUENCES[0x0A] = '\\n'; 7242 ESCAPE_SEQUENCES[0x0B] = '\\v'; 7243 ESCAPE_SEQUENCES[0x0C] = '\\f'; 7244 ESCAPE_SEQUENCES[0x0D] = '\\r'; 7245 ESCAPE_SEQUENCES[0x1B] = '\\e'; 7246 ESCAPE_SEQUENCES[0x22] = '\\"'; 7247 ESCAPE_SEQUENCES[0x5C] = '\\\\'; 7248 ESCAPE_SEQUENCES[0x85] = '\\N'; 7249 ESCAPE_SEQUENCES[0xA0] = '\\_'; 7250 ESCAPE_SEQUENCES[0x2028] = '\\L'; 7251 ESCAPE_SEQUENCES[0x2029] = '\\P'; 7252 7253 var DEPRECATED_BOOLEANS_SYNTAX = [ 7254 'y', 'Y', 'yes', 'Yes', 'YES', 'on', 'On', 'ON', 7255 'n', 'N', 'no', 'No', 'NO', 'off', 'Off', 'OFF' 7256 ]; 7257 7258 function compileStyleMap(schema, map) { 7259 var result, keys, index, length, tag, style, type; 7260 7261 if (null === map) { 7262 return {}; 7263 } 7264 7265 result = {}; 7266 keys = Object.keys(map); 7267 7268 for (index = 0, length = keys.length; index < length; index += 1) { 7269 tag = keys[index]; 7270 style = String(map[tag]); 7271 7272 if ('!!' === tag.slice(0, 2)) { 7273 tag = 'tag:yaml.org,2002:' + tag.slice(2); 7274 } 7275 7276 type = schema.compiledTypeMap[tag]; 7277 7278 if (type && _hasOwnProperty.call(type.styleAliases, style)) { 7279 style = type.styleAliases[style]; 7280 } 7281 7282 result[tag] = style; 7283 } 7284 7285 return result; 7286 } 7287 7288 function encodeHex(character) { 7289 var string, handle, length; 7290 7291 string = character.toString(16).toUpperCase(); 7292 7293 if (character <= 0xFF) { 7294 handle = 'x'; 7295 length = 2; 7296 } else if (character <= 0xFFFF) { 7297 handle = 'u'; 7298 length = 4; 7299 } else if (character <= 0xFFFFFFFF) { 7300 handle = 'U'; 7301 length = 8; 7302 } else { 7303 throw new YAMLException('code point within a string may not be greater than 0xFFFFFFFF'); 7304 } 7305 7306 return '\\' + handle + common.repeat('0', length - string.length) + string; 7307 } 7308 7309 function State(options) { 7310 this.schema = options['schema'] || DEFAULT_FULL_SCHEMA; 7311 this.indent = Math.max(1, (options['indent'] || 2)); 7312 this.skipInvalid = options['skipInvalid'] || false; 7313 this.flowLevel = (common.isNothing(options['flowLevel']) ? -1 : options['flowLevel']); 7314 this.styleMap = compileStyleMap(this.schema, options['styles'] || null); 7315 this.sortKeys = options['sortKeys'] || false; 7316 this.lineWidth = options['lineWidth'] || 80; 7317 7318 this.implicitTypes = this.schema.compiledImplicit; 7319 this.explicitTypes = this.schema.compiledExplicit; 7320 7321 this.tag = null; 7322 this.result = ''; 7323 7324 this.duplicates = []; 7325 this.usedDuplicates = null; 7326 } 7327 7328 function indentString(string, spaces) { 7329 var ind = common.repeat(' ', spaces), 7330 position = 0, 7331 next = -1, 7332 result = '', 7333 line, 7334 length = string.length; 7335 7336 while (position < length) { 7337 next = string.indexOf('\n', position); 7338 if (next === -1) { 7339 line = string.slice(position); 7340 position = length; 7341 } else { 7342 line = string.slice(position, next + 1); 7343 position = next + 1; 7344 } 7345 if (line.length && line !== '\n') { 7346 result += ind; 7347 } 7348 result += line; 7349 } 7350 7351 return result; 7352 } 7353 7354 function generateNextLine(state, level) { 7355 return '\n' + common.repeat(' ', state.indent * level); 7356 } 7357 7358 function testImplicitResolving(state, str) { 7359 var index, length, type; 7360 7361 for (index = 0, length = state.implicitTypes.length; index < length; index += 1) { 7362 type = state.implicitTypes[index]; 7363 7364 if (type.resolve(str)) { 7365 return true; 7366 } 7367 } 7368 7369 return false; 7370 } 7371 7372 function StringBuilder(source) { 7373 this.source = source; 7374 this.result = ''; 7375 this.checkpoint = 0; 7376 } 7377 7378 StringBuilder.prototype.takeUpTo = function (position) { 7379 var er; 7380 7381 if (position < this.checkpoint) { 7382 er = new Error('position should be > checkpoint'); 7383 er.position = position; 7384 er.checkpoint = this.checkpoint; 7385 throw er; 7386 } 7387 7388 this.result += this.source.slice(this.checkpoint, position); 7389 this.checkpoint = position; 7390 return this; 7391 }; 7392 7393 StringBuilder.prototype.escapeChar = function () { 7394 var character, esc; 7395 7396 character = this.source.charCodeAt(this.checkpoint); 7397 esc = ESCAPE_SEQUENCES[character] || encodeHex(character); 7398 this.result += esc; 7399 this.checkpoint += 1; 7400 7401 return this; 7402 }; 7403 7404 StringBuilder.prototype.finish = function () { 7405 if (this.source.length > this.checkpoint) { 7406 this.takeUpTo(this.source.length); 7407 } 7408 }; 7409 7410 function writeScalar(state, object, level, iskey) { 7411 var simple, first, spaceWrap, folded, literal, single, double, 7412 sawLineFeed, linePosition, longestLine, indent, max, character, 7413 position, escapeSeq, hexEsc, previous, lineLength, modifier, 7414 trailingLineBreaks, result; 7415 7416 if (0 === object.length) { 7417 state.dump = "''"; 7418 return; 7419 } 7420 7421 if (-1 !== DEPRECATED_BOOLEANS_SYNTAX.indexOf(object)) { 7422 state.dump = "'" + object + "'"; 7423 return; 7424 } 7425 7426 simple = true; 7427 first = object.length ? object.charCodeAt(0) : 0; 7428 spaceWrap = (CHAR_SPACE === first || 7429 CHAR_SPACE === object.charCodeAt(object.length - 1)); 7430 7431 // Simplified check for restricted first characters 7432 // http://www.yaml.org/spec/1.2/spec.html#ns-plain-first%28c%29 7433 if (CHAR_MINUS === first || 7434 CHAR_QUESTION === first || 7435 CHAR_COMMERCIAL_AT === first || 7436 CHAR_GRAVE_ACCENT === first) { 7437 simple = false; 7438 } 7439 7440 // can only use > and | if not wrapped in spaces or is not a key. 7441 if (spaceWrap) { 7442 simple = false; 7443 folded = false; 7444 literal = false; 7445 } else { 7446 folded = !iskey; 7447 literal = !iskey; 7448 } 7449 7450 single = true; 7451 double = new StringBuilder(object); 7452 7453 sawLineFeed = false; 7454 linePosition = 0; 7455 longestLine = 0; 7456 7457 indent = state.indent * level; 7458 max = state.lineWidth; 7459 if (max === -1) { 7460 // Replace -1 with biggest ingeger number according to 7461 // http://ecma262-5.com/ELS5_HTML.htm#Section_8.5 7462 max = 9007199254740991; 7463 } 7464 7465 if (indent < 40) { 7466 max -= indent; 7467 } else { 7468 max = 40; 7469 } 7470 7471 for (position = 0; position < object.length; position++) { 7472 character = object.charCodeAt(position); 7473 if (simple) { 7474 // Characters that can never appear in the simple scalar 7475 if (!simpleChar(character)) { 7476 simple = false; 7477 } else { 7478 // Still simple. If we make it all the way through like 7479 // this, then we can just dump the string as-is. 7480 continue; 7481 } 7482 } 7483 7484 if (single && character === CHAR_SINGLE_QUOTE) { 7485 single = false; 7486 } 7487 7488 escapeSeq = ESCAPE_SEQUENCES[character]; 7489 hexEsc = needsHexEscape(character); 7490 7491 if (!escapeSeq && !hexEsc) { 7492 continue; 7493 } 7494 7495 if (character !== CHAR_LINE_FEED && 7496 character !== CHAR_DOUBLE_QUOTE && 7497 character !== CHAR_SINGLE_QUOTE) { 7498 folded = false; 7499 literal = false; 7500 } else if (character === CHAR_LINE_FEED) { 7501 sawLineFeed = true; 7502 single = false; 7503 if (position > 0) { 7504 previous = object.charCodeAt(position - 1); 7505 if (previous === CHAR_SPACE) { 7506 literal = false; 7507 folded = false; 7508 } 7509 } 7510 if (folded) { 7511 lineLength = position - linePosition; 7512 linePosition = position; 7513 if (lineLength > longestLine) { 7514 longestLine = lineLength; 7515 } 7516 } 7517 } 7518 7519 if (character !== CHAR_DOUBLE_QUOTE) { 7520 single = false; 7521 } 7522 7523 double.takeUpTo(position); 7524 double.escapeChar(); 7525 } 7526 7527 if (simple && testImplicitResolving(state, object)) { 7528 simple = false; 7529 } 7530 7531 modifier = ''; 7532 if (folded || literal) { 7533 trailingLineBreaks = 0; 7534 if (object.charCodeAt(object.length - 1) === CHAR_LINE_FEED) { 7535 trailingLineBreaks += 1; 7536 if (object.charCodeAt(object.length - 2) === CHAR_LINE_FEED) { 7537 trailingLineBreaks += 1; 7538 } 7539 } 7540 7541 if (trailingLineBreaks === 0) { 7542 modifier = '-'; 7543 } else if (trailingLineBreaks === 2) { 7544 modifier = '+'; 7545 } 7546 } 7547 7548 if (literal && longestLine < max) { 7549 folded = false; 7550 } 7551 7552 // If it's literally one line, then don't bother with the literal. 7553 // We may still want to do a fold, though, if it's a super long line. 7554 if (!sawLineFeed) { 7555 literal = false; 7556 } 7557 7558 if (simple) { 7559 state.dump = object; 7560 } else if (single) { 7561 state.dump = '\'' + object + '\''; 7562 } else if (folded) { 7563 result = fold(object, max); 7564 state.dump = '>' + modifier + '\n' + indentString(result, indent); 7565 } else if (literal) { 7566 if (!modifier) { 7567 object = object.replace(/\n$/, ''); 7568 } 7569 state.dump = '|' + modifier + '\n' + indentString(object, indent); 7570 } else if (double) { 7571 double.finish(); 7572 state.dump = '"' + double.result + '"'; 7573 } else { 7574 throw new Error('Failed to dump scalar value'); 7575 } 7576 7577 return; 7578 } 7579 7580 // The `trailing` var is a regexp match of any trailing `\n` characters. 7581 // 7582 // There are three cases we care about: 7583 // 7584 // 1. One trailing `\n` on the string. Just use `|` or `>`. 7585 // This is the assumed default. (trailing = null) 7586 // 2. No trailing `\n` on the string. Use `|-` or `>-` to "chomp" the end. 7587 // 3. More than one trailing `\n` on the string. Use `|+` or `>+`. 7588 // 7589 // In the case of `>+`, these line breaks are *not* doubled (like the line 7590 // breaks within the string), so it's important to only end with the exact 7591 // same number as we started. 7592 function fold(object, max) { 7593 var result = '', 7594 position = 0, 7595 length = object.length, 7596 trailing = /\n+$/.exec(object), 7597 newLine; 7598 7599 if (trailing) { 7600 length = trailing.index + 1; 7601 } 7602 7603 while (position < length) { 7604 newLine = object.indexOf('\n', position); 7605 if (newLine > length || newLine === -1) { 7606 if (result) { 7607 result += '\n\n'; 7608 } 7609 result += foldLine(object.slice(position, length), max); 7610 position = length; 7611 } else { 7612 if (result) { 7613 result += '\n\n'; 7614 } 7615 result += foldLine(object.slice(position, newLine), max); 7616 position = newLine + 1; 7617 } 7618 } 7619 if (trailing && trailing[0] !== '\n') { 7620 result += trailing[0]; 7621 } 7622 7623 return result; 7624 } 7625 7626 function foldLine(line, max) { 7627 if (line === '') { 7628 return line; 7629 } 7630 7631 var foldRe = /[^\s] [^\s]/g, 7632 result = '', 7633 prevMatch = 0, 7634 foldStart = 0, 7635 match = foldRe.exec(line), 7636 index, 7637 foldEnd, 7638 folded; 7639 7640 while (match) { 7641 index = match.index; 7642 7643 // when we cross the max len, if the previous match would've 7644 // been ok, use that one, and carry on. If there was no previous 7645 // match on this fold section, then just have a long line. 7646 if (index - foldStart > max) { 7647 if (prevMatch !== foldStart) { 7648 foldEnd = prevMatch; 7649 } else { 7650 foldEnd = index; 7651 } 7652 7653 if (result) { 7654 result += '\n'; 7655 } 7656 folded = line.slice(foldStart, foldEnd); 7657 result += folded; 7658 foldStart = foldEnd + 1; 7659 } 7660 prevMatch = index + 1; 7661 match = foldRe.exec(line); 7662 } 7663 7664 if (result) { 7665 result += '\n'; 7666 } 7667 7668 // if we end up with one last word at the end, then the last bit might 7669 // be slightly bigger than we wanted, because we exited out of the loop. 7670 if (foldStart !== prevMatch && line.length - foldStart > max) { 7671 result += line.slice(foldStart, prevMatch) + '\n' + 7672 line.slice(prevMatch + 1); 7673 } else { 7674 result += line.slice(foldStart); 7675 } 7676 7677 return result; 7678 } 7679 7680 // Returns true if character can be found in a simple scalar 7681 function simpleChar(character) { 7682 return CHAR_TAB !== character && 7683 CHAR_LINE_FEED !== character && 7684 CHAR_CARRIAGE_RETURN !== character && 7685 CHAR_COMMA !== character && 7686 CHAR_LEFT_SQUARE_BRACKET !== character && 7687 CHAR_RIGHT_SQUARE_BRACKET !== character && 7688 CHAR_LEFT_CURLY_BRACKET !== character && 7689 CHAR_RIGHT_CURLY_BRACKET !== character && 7690 CHAR_SHARP !== character && 7691 CHAR_AMPERSAND !== character && 7692 CHAR_ASTERISK !== character && 7693 CHAR_EXCLAMATION !== character && 7694 CHAR_VERTICAL_LINE !== character && 7695 CHAR_GREATER_THAN !== character && 7696 CHAR_SINGLE_QUOTE !== character && 7697 CHAR_DOUBLE_QUOTE !== character && 7698 CHAR_PERCENT !== character && 7699 CHAR_COLON !== character && 7700 !ESCAPE_SEQUENCES[character] && 7701 !needsHexEscape(character); 7702 } 7703 7704 // Returns true if the character code needs to be escaped. 7705 function needsHexEscape(character) { 7706 return !((0x00020 <= character && character <= 0x00007E) || 7707 (0x00085 === character) || 7708 (0x000A0 <= character && character <= 0x00D7FF) || 7709 (0x0E000 <= character && character <= 0x00FFFD) || 7710 (0x10000 <= character && character <= 0x10FFFF)); 7711 } 7712 7713 function writeFlowSequence(state, level, object) { 7714 var _result = '', 7715 _tag = state.tag, 7716 index, 7717 length; 7718 7719 for (index = 0, length = object.length; index < length; index += 1) { 7720 // Write only valid elements. 7721 if (writeNode(state, level, object[index], false, false)) { 7722 if (0 !== index) { 7723 _result += ', '; 7724 } 7725 _result += state.dump; 7726 } 7727 } 7728 7729 state.tag = _tag; 7730 state.dump = '[' + _result + ']'; 7731 } 7732 7733 function writeBlockSequence(state, level, object, compact) { 7734 var _result = '', 7735 _tag = state.tag, 7736 index, 7737 length; 7738 7739 for (index = 0, length = object.length; index < length; index += 1) { 7740 // Write only valid elements. 7741 if (writeNode(state, level + 1, object[index], true, true)) { 7742 if (!compact || 0 !== index) { 7743 _result += generateNextLine(state, level); 7744 } 7745 _result += '- ' + state.dump; 7746 } 7747 } 7748 7749 state.tag = _tag; 7750 state.dump = _result || '[]'; // Empty sequence if no valid values. 7751 } 7752 7753 function writeFlowMapping(state, level, object) { 7754 var _result = '', 7755 _tag = state.tag, 7756 objectKeyList = Object.keys(object), 7757 index, 7758 length, 7759 objectKey, 7760 objectValue, 7761 pairBuffer; 7762 7763 for (index = 0, length = objectKeyList.length; index < length; index += 1) { 7764 pairBuffer = ''; 7765 7766 if (0 !== index) { 7767 pairBuffer += ', '; 7768 } 7769 7770 objectKey = objectKeyList[index]; 7771 objectValue = object[objectKey]; 7772 7773 if (!writeNode(state, level, objectKey, false, false)) { 7774 continue; // Skip this pair because of invalid key; 7775 } 7776 7777 if (state.dump.length > 1024) { 7778 pairBuffer += '? '; 7779 } 7780 7781 pairBuffer += state.dump + ': '; 7782 7783 if (!writeNode(state, level, objectValue, false, false)) { 7784 continue; // Skip this pair because of invalid value. 7785 } 7786 7787 pairBuffer += state.dump; 7788 7789 // Both key and value are valid. 7790 _result += pairBuffer; 7791 } 7792 7793 state.tag = _tag; 7794 state.dump = '{' + _result + '}'; 7795 } 7796 7797 function writeBlockMapping(state, level, object, compact) { 7798 var _result = '', 7799 _tag = state.tag, 7800 objectKeyList = Object.keys(object), 7801 index, 7802 length, 7803 objectKey, 7804 objectValue, 7805 explicitPair, 7806 pairBuffer; 7807 7808 // Allow sorting keys so that the output file is deterministic 7809 if (state.sortKeys === true) { 7810 // Default sorting 7811 objectKeyList.sort(); 7812 } else if (typeof state.sortKeys === 'function') { 7813 // Custom sort function 7814 objectKeyList.sort(state.sortKeys); 7815 } else if (state.sortKeys) { 7816 // Something is wrong 7817 throw new YAMLException('sortKeys must be a boolean or a function'); 7818 } 7819 7820 for (index = 0, length = objectKeyList.length; index < length; index += 1) { 7821 pairBuffer = ''; 7822 7823 if (!compact || 0 !== index) { 7824 pairBuffer += generateNextLine(state, level); 7825 } 7826 7827 objectKey = objectKeyList[index]; 7828 objectValue = object[objectKey]; 7829 7830 if (!writeNode(state, level + 1, objectKey, true, true, true)) { 7831 continue; // Skip this pair because of invalid key. 7832 } 7833 7834 explicitPair = (null !== state.tag && '?' !== state.tag) || 7835 (state.dump && state.dump.length > 1024); 7836 7837 if (explicitPair) { 7838 if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) { 7839 pairBuffer += '?'; 7840 } else { 7841 pairBuffer += '? '; 7842 } 7843 } 7844 7845 pairBuffer += state.dump; 7846 7847 if (explicitPair) { 7848 pairBuffer += generateNextLine(state, level); 7849 } 7850 7851 if (!writeNode(state, level + 1, objectValue, true, explicitPair)) { 7852 continue; // Skip this pair because of invalid value. 7853 } 7854 7855 if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) { 7856 pairBuffer += ':'; 7857 } else { 7858 pairBuffer += ': '; 7859 } 7860 7861 pairBuffer += state.dump; 7862 7863 // Both key and value are valid. 7864 _result += pairBuffer; 7865 } 7866 7867 state.tag = _tag; 7868 state.dump = _result || '{}'; // Empty mapping if no valid pairs. 7869 } 7870 7871 function detectType(state, object, explicit) { 7872 var _result, typeList, index, length, type, style; 7873 7874 typeList = explicit ? state.explicitTypes : state.implicitTypes; 7875 7876 for (index = 0, length = typeList.length; index < length; index += 1) { 7877 type = typeList[index]; 7878 7879 if ((type.instanceOf || type.predicate) && 7880 (!type.instanceOf || (('object' === typeof object) && (object instanceof type.instanceOf))) && 7881 (!type.predicate || type.predicate(object))) { 7882 7883 state.tag = explicit ? type.tag : '?'; 7884 7885 if (type.represent) { 7886 style = state.styleMap[type.tag] || type.defaultStyle; 7887 7888 if ('[object Function]' === _toString.call(type.represent)) { 7889 _result = type.represent(object, style); 7890 } else if (_hasOwnProperty.call(type.represent, style)) { 7891 _result = type.represent[style](object, style); 7892 } else { 7893 throw new YAMLException('!<' + type.tag + '> tag resolver accepts not "' + style + '" style'); 7894 } 7895 7896 state.dump = _result; 7897 } 7898 7899 return true; 7900 } 7901 } 7902 7903 return false; 7904 } 7905 7906 // Serializes `object` and writes it to global `result`. 7907 // Returns true on success, or false on invalid object. 7908 // 7909 function writeNode(state, level, object, block, compact, iskey) { 7910 state.tag = null; 7911 state.dump = object; 7912 7913 if (!detectType(state, object, false)) { 7914 detectType(state, object, true); 7915 } 7916 7917 var type = _toString.call(state.dump); 7918 7919 if (block) { 7920 block = (0 > state.flowLevel || state.flowLevel > level); 7921 } 7922 7923 var objectOrArray = '[object Object]' === type || '[object Array]' === type, 7924 duplicateIndex, 7925 duplicate; 7926 7927 if (objectOrArray) { 7928 duplicateIndex = state.duplicates.indexOf(object); 7929 duplicate = duplicateIndex !== -1; 7930 } 7931 7932 if ((null !== state.tag && '?' !== state.tag) || duplicate || (2 !== state.indent && level > 0)) { 7933 compact = false; 7934 } 7935 7936 if (duplicate && state.usedDuplicates[duplicateIndex]) { 7937 state.dump = '*ref_' + duplicateIndex; 7938 } else { 7939 if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) { 7940 state.usedDuplicates[duplicateIndex] = true; 7941 } 7942 if ('[object Object]' === type) { 7943 if (block && (0 !== Object.keys(state.dump).length)) { 7944 writeBlockMapping(state, level, state.dump, compact); 7945 if (duplicate) { 7946 state.dump = '&ref_' + duplicateIndex + state.dump; 7947 } 7948 } else { 7949 writeFlowMapping(state, level, state.dump); 7950 if (duplicate) { 7951 state.dump = '&ref_' + duplicateIndex + ' ' + state.dump; 7952 } 7953 } 7954 } else if ('[object Array]' === type) { 7955 if (block && (0 !== state.dump.length)) { 7956 writeBlockSequence(state, level, state.dump, compact); 7957 if (duplicate) { 7958 state.dump = '&ref_' + duplicateIndex + state.dump; 7959 } 7960 } else { 7961 writeFlowSequence(state, level, state.dump); 7962 if (duplicate) { 7963 state.dump = '&ref_' + duplicateIndex + ' ' + state.dump; 7964 } 7965 } 7966 } else if ('[object String]' === type) { 7967 if ('?' !== state.tag) { 7968 writeScalar(state, state.dump, level, iskey); 7969 } 7970 } else { 7971 if (state.skipInvalid) { 7972 return false; 7973 } 7974 throw new YAMLException('unacceptable kind of an object to dump ' + type); 7975 } 7976 7977 if (null !== state.tag && '?' !== state.tag) { 7978 state.dump = '!<' + state.tag + '> ' + state.dump; 7979 } 7980 } 7981 7982 return true; 7983 } 7984 7985 function getDuplicateReferences(object, state) { 7986 var objects = [], 7987 duplicatesIndexes = [], 7988 index, 7989 length; 7990 7991 inspectNode(object, objects, duplicatesIndexes); 7992 7993 for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) { 7994 state.duplicates.push(objects[duplicatesIndexes[index]]); 7995 } 7996 state.usedDuplicates = new Array(length); 7997 } 7998 7999 function inspectNode(object, objects, duplicatesIndexes) { 8000 var objectKeyList, 8001 index, 8002 length; 8003 8004 if (null !== object && 'object' === typeof object) { 8005 index = objects.indexOf(object); 8006 if (-1 !== index) { 8007 if (-1 === duplicatesIndexes.indexOf(index)) { 8008 duplicatesIndexes.push(index); 8009 } 8010 } else { 8011 objects.push(object); 8012 8013 if (Array.isArray(object)) { 8014 for (index = 0, length = object.length; index < length; index += 1) { 8015 inspectNode(object[index], objects, duplicatesIndexes); 8016 } 8017 } else { 8018 objectKeyList = Object.keys(object); 8019 8020 for (index = 0, length = objectKeyList.length; index < length; index += 1) { 8021 inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes); 8022 } 8023 } 8024 } 8025 } 8026 } 8027 8028 function dump(input, options) { 8029 options = options || {}; 8030 8031 var state = new State(options); 8032 8033 getDuplicateReferences(input, state); 8034 8035 if (writeNode(state, 0, input, true, true)) { 8036 return state.dump + '\n'; 8037 } 8038 return ''; 8039 } 8040 8041 function safeDump(input, options) { 8042 return dump(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options)); 8043 } 8044 8045 module.exports.dump = dump; 8046 module.exports.safeDump = safeDump; 8047 8048 },{"./common":22,"./exception":24,"./schema/default_full":29,"./schema/default_safe":30}],24:[function(require,module,exports){ 8049 // YAML error class. http://stackoverflow.com/questions/8458984 8050 // 8051 'use strict'; 8052 8053 8054 var inherits = require('inherit'); 8055 8056 8057 function YAMLException(reason, mark) { 8058 // Super constructor 8059 Error.call(this); 8060 8061 // Include stack trace in error object 8062 if (Error.captureStackTrace) { 8063 // Chrome and NodeJS 8064 Error.captureStackTrace(this, this.constructor); 8065 } else { 8066 // FF, IE 10+ and Safari 6+. Fallback for others 8067 this.stack = (new Error()).stack || ''; 8068 } 8069 8070 this.name = 'YAMLException'; 8071 this.reason = reason; 8072 this.mark = mark; 8073 this.message = (this.reason || '(unknown reason)') + (this.mark ? ' ' + this.mark.toString() : ''); 8074 } 8075 8076 8077 // Inherit from Error 8078 inherits(YAMLException, Error); 8079 8080 8081 YAMLException.prototype.toString = function toString(compact) { 8082 var result = this.name + ': '; 8083 8084 result += this.reason || '(unknown reason)'; 8085 8086 if (!compact && this.mark) { 8087 result += ' ' + this.mark.toString(); 8088 } 8089 8090 return result; 8091 }; 8092 8093 8094 module.exports = YAMLException; 8095 8096 },{"inherit":51}],25:[function(require,module,exports){ 8097 'use strict'; 8098 8099 /*eslint-disable max-len,no-use-before-define*/ 8100 8101 var common = require('./common'); 8102 var YAMLException = require('./exception'); 8103 var Mark = require('./mark'); 8104 var DEFAULT_SAFE_SCHEMA = require('./schema/default_safe'); 8105 var DEFAULT_FULL_SCHEMA = require('./schema/default_full'); 8106 8107 8108 var _hasOwnProperty = Object.prototype.hasOwnProperty; 8109 8110 8111 var CONTEXT_FLOW_IN = 1; 8112 var CONTEXT_FLOW_OUT = 2; 8113 var CONTEXT_BLOCK_IN = 3; 8114 var CONTEXT_BLOCK_OUT = 4; 8115 8116 8117 var CHOMPING_CLIP = 1; 8118 var CHOMPING_STRIP = 2; 8119 var CHOMPING_KEEP = 3; 8120 8121 8122 var PATTERN_NON_PRINTABLE = /[\x00-\x08\x0B\x0C\x0E-\x1F\x7F-\x84\x86-\x9F\uFFFE\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]/; 8123 var PATTERN_NON_ASCII_LINE_BREAKS = /[\x85\u2028\u2029]/; 8124 var PATTERN_FLOW_INDICATORS = /[,\[\]\{\}]/; 8125 var PATTERN_TAG_HANDLE = /^(?:!|!!|![a-z\-]+!)$/i; 8126 var PATTERN_TAG_URI = /^(?:!|[^,\[\]\{\}])(?:%[0-9a-f]{2}|[0-9a-z\-#;\/\?:@&=\+\$,_\.!~\*'\(\)\[\]])*$/i; 8127 8128 8129 function is_EOL(c) { 8130 return (c === 0x0A/* LF */) || (c === 0x0D/* CR */); 8131 } 8132 8133 function is_WHITE_SPACE(c) { 8134 return (c === 0x09/* Tab */) || (c === 0x20/* Space */); 8135 } 8136 8137 function is_WS_OR_EOL(c) { 8138 return (c === 0x09/* Tab */) || 8139 (c === 0x20/* Space */) || 8140 (c === 0x0A/* LF */) || 8141 (c === 0x0D/* CR */); 8142 } 8143 8144 function is_FLOW_INDICATOR(c) { 8145 return 0x2C/* , */ === c || 8146 0x5B/* [ */ === c || 8147 0x5D/* ] */ === c || 8148 0x7B/* { */ === c || 8149 0x7D/* } */ === c; 8150 } 8151 8152 function fromHexCode(c) { 8153 var lc; 8154 8155 if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) { 8156 return c - 0x30; 8157 } 8158 8159 /*eslint-disable no-bitwise*/ 8160 lc = c | 0x20; 8161 8162 if ((0x61/* a */ <= lc) && (lc <= 0x66/* f */)) { 8163 return lc - 0x61 + 10; 8164 } 8165 8166 return -1; 8167 } 8168 8169 function escapedHexLen(c) { 8170 if (c === 0x78/* x */) { return 2; } 8171 if (c === 0x75/* u */) { return 4; } 8172 if (c === 0x55/* U */) { return 8; } 8173 return 0; 8174 } 8175 8176 function fromDecimalCode(c) { 8177 if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) { 8178 return c - 0x30; 8179 } 8180 8181 return -1; 8182 } 8183 8184 function simpleEscapeSequence(c) { 8185 return (c === 0x30/* 0 */) ? '\x00' : 8186 (c === 0x61/* a */) ? '\x07' : 8187 (c === 0x62/* b */) ? '\x08' : 8188 (c === 0x74/* t */) ? '\x09' : 8189 (c === 0x09/* Tab */) ? '\x09' : 8190 (c === 0x6E/* n */) ? '\x0A' : 8191 (c === 0x76/* v */) ? '\x0B' : 8192 (c === 0x66/* f */) ? '\x0C' : 8193 (c === 0x72/* r */) ? '\x0D' : 8194 (c === 0x65/* e */) ? '\x1B' : 8195 (c === 0x20/* Space */) ? ' ' : 8196 (c === 0x22/* " */) ? '\x22' : 8197 (c === 0x2F/* / */) ? '/' : 8198 (c === 0x5C/* \ */) ? '\x5C' : 8199 (c === 0x4E/* N */) ? '\x85' : 8200 (c === 0x5F/* _ */) ? '\xA0' : 8201 (c === 0x4C/* L */) ? '\u2028' : 8202 (c === 0x50/* P */) ? '\u2029' : ''; 8203 } 8204 8205 function charFromCodepoint(c) { 8206 if (c <= 0xFFFF) { 8207 return String.fromCharCode(c); 8208 } 8209 // Encode UTF-16 surrogate pair 8210 // https://en.wikipedia.org/wiki/UTF-16#Code_points_U.2B010000_to_U.2B10FFFF 8211 return String.fromCharCode(((c - 0x010000) >> 10) + 0xD800, 8212 ((c - 0x010000) & 0x03FF) + 0xDC00); 8213 } 8214 8215 var simpleEscapeCheck = new Array(256); // integer, for fast access 8216 var simpleEscapeMap = new Array(256); 8217 for (var i = 0; i < 256; i++) { 8218 simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0; 8219 simpleEscapeMap[i] = simpleEscapeSequence(i); 8220 } 8221 8222 8223 function State(input, options) { 8224 this.input = input; 8225 8226 this.filename = options['filename'] || null; 8227 this.schema = options['schema'] || DEFAULT_FULL_SCHEMA; 8228 this.onWarning = options['onWarning'] || null; 8229 this.legacy = options['legacy'] || false; 8230 8231 this.implicitTypes = this.schema.compiledImplicit; 8232 this.typeMap = this.schema.compiledTypeMap; 8233 8234 this.length = input.length; 8235 this.position = 0; 8236 this.line = 0; 8237 this.lineStart = 0; 8238 this.lineIndent = 0; 8239 8240 this.documents = []; 8241 8242 /* 8243 this.version; 8244 this.checkLineBreaks; 8245 this.tagMap; 8246 this.anchorMap; 8247 this.tag; 8248 this.anchor; 8249 this.kind; 8250 this.result;*/ 8251 8252 } 8253 8254 8255 function generateError(state, message) { 8256 return new YAMLException( 8257 message, 8258 new Mark(state.filename, state.input, state.position, state.line, (state.position - state.lineStart))); 8259 } 8260 8261 function throwError(state, message) { 8262 throw generateError(state, message); 8263 } 8264 8265 function throwWarning(state, message) { 8266 if (state.onWarning) { 8267 state.onWarning.call(null, generateError(state, message)); 8268 } 8269 } 8270 8271 8272 var directiveHandlers = { 8273 8274 YAML: function handleYamlDirective(state, name, args) { 8275 8276 var match, major, minor; 8277 8278 if (null !== state.version) { 8279 throwError(state, 'duplication of %YAML directive'); 8280 } 8281 8282 if (1 !== args.length) { 8283 throwError(state, 'YAML directive accepts exactly one argument'); 8284 } 8285 8286 match = /^([0-9]+)\.([0-9]+)$/.exec(args[0]); 8287 8288 if (null === match) { 8289 throwError(state, 'ill-formed argument of the YAML directive'); 8290 } 8291 8292 major = parseInt(match[1], 10); 8293 minor = parseInt(match[2], 10); 8294 8295 if (1 !== major) { 8296 throwError(state, 'unacceptable YAML version of the document'); 8297 } 8298 8299 state.version = args[0]; 8300 state.checkLineBreaks = (minor < 2); 8301 8302 if (1 !== minor && 2 !== minor) { 8303 throwWarning(state, 'unsupported YAML version of the document'); 8304 } 8305 }, 8306 8307 TAG: function handleTagDirective(state, name, args) { 8308 8309 var handle, prefix; 8310 8311 if (2 !== args.length) { 8312 throwError(state, 'TAG directive accepts exactly two arguments'); 8313 } 8314 8315 handle = args[0]; 8316 prefix = args[1]; 8317 8318 if (!PATTERN_TAG_HANDLE.test(handle)) { 8319 throwError(state, 'ill-formed tag handle (first argument) of the TAG directive'); 8320 } 8321 8322 if (_hasOwnProperty.call(state.tagMap, handle)) { 8323 throwError(state, 'there is a previously declared suffix for "' + handle + '" tag handle'); 8324 } 8325 8326 if (!PATTERN_TAG_URI.test(prefix)) { 8327 throwError(state, 'ill-formed tag prefix (second argument) of the TAG directive'); 8328 } 8329 8330 state.tagMap[handle] = prefix; 8331 } 8332 }; 8333 8334 8335 function captureSegment(state, start, end, checkJson) { 8336 var _position, _length, _character, _result; 8337 8338 if (start < end) { 8339 _result = state.input.slice(start, end); 8340 8341 if (checkJson) { 8342 for (_position = 0, _length = _result.length; 8343 _position < _length; 8344 _position += 1) { 8345 _character = _result.charCodeAt(_position); 8346 if (!(0x09 === _character || 8347 0x20 <= _character && _character <= 0x10FFFF)) { 8348 throwError(state, 'expected valid JSON character'); 8349 } 8350 } 8351 } else if (PATTERN_NON_PRINTABLE.test(_result)) { 8352 throwError(state, 'the stream contains non-printable characters'); 8353 } 8354 8355 state.result += _result; 8356 } 8357 } 8358 8359 function mergeMappings(state, destination, source) { 8360 var sourceKeys, key, index, quantity; 8361 8362 if (!common.isObject(source)) { 8363 throwError(state, 'cannot merge mappings; the provided source object is unacceptable'); 8364 } 8365 8366 sourceKeys = Object.keys(source); 8367 8368 for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) { 8369 key = sourceKeys[index]; 8370 8371 if (!_hasOwnProperty.call(destination, key)) { 8372 destination[key] = source[key]; 8373 } 8374 } 8375 } 8376 8377 function storeMappingPair(state, _result, keyTag, keyNode, valueNode) { 8378 var index, quantity; 8379 8380 keyNode = String(keyNode); 8381 8382 if (null === _result) { 8383 _result = {}; 8384 } 8385 8386 if ('tag:yaml.org,2002:merge' === keyTag) { 8387 if (Array.isArray(valueNode)) { 8388 for (index = 0, quantity = valueNode.length; index < quantity; index += 1) { 8389 mergeMappings(state, _result, valueNode[index]); 8390 } 8391 } else { 8392 mergeMappings(state, _result, valueNode); 8393 } 8394 } else { 8395 _result[keyNode] = valueNode; 8396 } 8397 8398 return _result; 8399 } 8400 8401 function readLineBreak(state) { 8402 var ch; 8403 8404 ch = state.input.charCodeAt(state.position); 8405 8406 if (0x0A/* LF */ === ch) { 8407 state.position++; 8408 } else if (0x0D/* CR */ === ch) { 8409 state.position++; 8410 if (0x0A/* LF */ === state.input.charCodeAt(state.position)) { 8411 state.position++; 8412 } 8413 } else { 8414 throwError(state, 'a line break is expected'); 8415 } 8416 8417 state.line += 1; 8418 state.lineStart = state.position; 8419 } 8420 8421 function skipSeparationSpace(state, allowComments, checkIndent) { 8422 var lineBreaks = 0, 8423 ch = state.input.charCodeAt(state.position); 8424 8425 while (0 !== ch) { 8426 while (is_WHITE_SPACE(ch)) { 8427 ch = state.input.charCodeAt(++state.position); 8428 } 8429 8430 if (allowComments && 0x23/* # */ === ch) { 8431 do { 8432 ch = state.input.charCodeAt(++state.position); 8433 } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && 0 !== ch); 8434 } 8435 8436 if (is_EOL(ch)) { 8437 readLineBreak(state); 8438 8439 ch = state.input.charCodeAt(state.position); 8440 lineBreaks++; 8441 state.lineIndent = 0; 8442 8443 while (0x20/* Space */ === ch) { 8444 state.lineIndent++; 8445 ch = state.input.charCodeAt(++state.position); 8446 } 8447 } else { 8448 break; 8449 } 8450 } 8451 8452 if (-1 !== checkIndent && 0 !== lineBreaks && state.lineIndent < checkIndent) { 8453 throwWarning(state, 'deficient indentation'); 8454 } 8455 8456 return lineBreaks; 8457 } 8458 8459 function testDocumentSeparator(state) { 8460 var _position = state.position, 8461 ch; 8462 8463 ch = state.input.charCodeAt(_position); 8464 8465 // Condition state.position === state.lineStart is tested 8466 // in parent on each call, for efficiency. No needs to test here again. 8467 if ((0x2D/* - */ === ch || 0x2E/* . */ === ch) && 8468 state.input.charCodeAt(_position + 1) === ch && 8469 state.input.charCodeAt(_position + 2) === ch) { 8470 8471 _position += 3; 8472 8473 ch = state.input.charCodeAt(_position); 8474 8475 if (ch === 0 || is_WS_OR_EOL(ch)) { 8476 return true; 8477 } 8478 } 8479 8480 return false; 8481 } 8482 8483 function writeFoldedLines(state, count) { 8484 if (1 === count) { 8485 state.result += ' '; 8486 } else if (count > 1) { 8487 state.result += common.repeat('\n', count - 1); 8488 } 8489 } 8490 8491 8492 function readPlainScalar(state, nodeIndent, withinFlowCollection) { 8493 var preceding, 8494 following, 8495 captureStart, 8496 captureEnd, 8497 hasPendingContent, 8498 _line, 8499 _lineStart, 8500 _lineIndent, 8501 _kind = state.kind, 8502 _result = state.result, 8503 ch; 8504 8505 ch = state.input.charCodeAt(state.position); 8506 8507 if (is_WS_OR_EOL(ch) || 8508 is_FLOW_INDICATOR(ch) || 8509 0x23/* # */ === ch || 8510 0x26/* & */ === ch || 8511 0x2A/* * */ === ch || 8512 0x21/* ! */ === ch || 8513 0x7C/* | */ === ch || 8514 0x3E/* > */ === ch || 8515 0x27/* ' */ === ch || 8516 0x22/* " */ === ch || 8517 0x25/* % */ === ch || 8518 0x40/* @ */ === ch || 8519 0x60/* ` */ === ch) { 8520 return false; 8521 } 8522 8523 if (0x3F/* ? */ === ch || 0x2D/* - */ === ch) { 8524 following = state.input.charCodeAt(state.position + 1); 8525 8526 if (is_WS_OR_EOL(following) || 8527 withinFlowCollection && is_FLOW_INDICATOR(following)) { 8528 return false; 8529 } 8530 } 8531 8532 state.kind = 'scalar'; 8533 state.result = ''; 8534 captureStart = captureEnd = state.position; 8535 hasPendingContent = false; 8536 8537 while (0 !== ch) { 8538 if (0x3A/* : */ === ch) { 8539 following = state.input.charCodeAt(state.position + 1); 8540 8541 if (is_WS_OR_EOL(following) || 8542 withinFlowCollection && is_FLOW_INDICATOR(following)) { 8543 break; 8544 } 8545 8546 } else if (0x23/* # */ === ch) { 8547 preceding = state.input.charCodeAt(state.position - 1); 8548 8549 if (is_WS_OR_EOL(preceding)) { 8550 break; 8551 } 8552 8553 } else if ((state.position === state.lineStart && testDocumentSeparator(state)) || 8554 withinFlowCollection && is_FLOW_INDICATOR(ch)) { 8555 break; 8556 8557 } else if (is_EOL(ch)) { 8558 _line = state.line; 8559 _lineStart = state.lineStart; 8560 _lineIndent = state.lineIndent; 8561 skipSeparationSpace(state, false, -1); 8562 8563 if (state.lineIndent >= nodeIndent) { 8564 hasPendingContent = true; 8565 ch = state.input.charCodeAt(state.position); 8566 continue; 8567 } else { 8568 state.position = captureEnd; 8569 state.line = _line; 8570 state.lineStart = _lineStart; 8571 state.lineIndent = _lineIndent; 8572 break; 8573 } 8574 } 8575 8576 if (hasPendingContent) { 8577 captureSegment(state, captureStart, captureEnd, false); 8578 writeFoldedLines(state, state.line - _line); 8579 captureStart = captureEnd = state.position; 8580 hasPendingContent = false; 8581 } 8582 8583 if (!is_WHITE_SPACE(ch)) { 8584 captureEnd = state.position + 1; 8585 } 8586 8587 ch = state.input.charCodeAt(++state.position); 8588 } 8589 8590 captureSegment(state, captureStart, captureEnd, false); 8591 8592 if (state.result) { 8593 return true; 8594 } 8595 8596 state.kind = _kind; 8597 state.result = _result; 8598 return false; 8599 } 8600 8601 function readSingleQuotedScalar(state, nodeIndent) { 8602 var ch, 8603 captureStart, captureEnd; 8604 8605 ch = state.input.charCodeAt(state.position); 8606 8607 if (0x27/* ' */ !== ch) { 8608 return false; 8609 } 8610 8611 state.kind = 'scalar'; 8612 state.result = ''; 8613 state.position++; 8614 captureStart = captureEnd = state.position; 8615 8616 while (0 !== (ch = state.input.charCodeAt(state.position))) { 8617 if (0x27/* ' */ === ch) { 8618 captureSegment(state, captureStart, state.position, true); 8619 ch = state.input.charCodeAt(++state.position); 8620 8621 if (0x27/* ' */ === ch) { 8622 captureStart = captureEnd = state.position; 8623 state.position++; 8624 } else { 8625 return true; 8626 } 8627 8628 } else if (is_EOL(ch)) { 8629 captureSegment(state, captureStart, captureEnd, true); 8630 writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent)); 8631 captureStart = captureEnd = state.position; 8632 8633 } else if (state.position === state.lineStart && testDocumentSeparator(state)) { 8634 throwError(state, 'unexpected end of the document within a single quoted scalar'); 8635 8636 } else { 8637 state.position++; 8638 captureEnd = state.position; 8639 } 8640 } 8641 8642 throwError(state, 'unexpected end of the stream within a single quoted scalar'); 8643 } 8644 8645 function readDoubleQuotedScalar(state, nodeIndent) { 8646 var captureStart, 8647 captureEnd, 8648 hexLength, 8649 hexResult, 8650 tmp, 8651 ch; 8652 8653 ch = state.input.charCodeAt(state.position); 8654 8655 if (0x22/* " */ !== ch) { 8656 return false; 8657 } 8658 8659 state.kind = 'scalar'; 8660 state.result = ''; 8661 state.position++; 8662 captureStart = captureEnd = state.position; 8663 8664 while (0 !== (ch = state.input.charCodeAt(state.position))) { 8665 if (0x22/* " */ === ch) { 8666 captureSegment(state, captureStart, state.position, true); 8667 state.position++; 8668 return true; 8669 8670 } else if (0x5C/* \ */ === ch) { 8671 captureSegment(state, captureStart, state.position, true); 8672 ch = state.input.charCodeAt(++state.position); 8673 8674 if (is_EOL(ch)) { 8675 skipSeparationSpace(state, false, nodeIndent); 8676 8677 // TODO: rework to inline fn with no type cast? 8678 } else if (ch < 256 && simpleEscapeCheck[ch]) { 8679 state.result += simpleEscapeMap[ch]; 8680 state.position++; 8681 8682 } else if ((tmp = escapedHexLen(ch)) > 0) { 8683 hexLength = tmp; 8684 hexResult = 0; 8685 8686 for (; hexLength > 0; hexLength--) { 8687 ch = state.input.charCodeAt(++state.position); 8688 8689 if ((tmp = fromHexCode(ch)) >= 0) { 8690 hexResult = (hexResult << 4) + tmp; 8691 8692 } else { 8693 throwError(state, 'expected hexadecimal character'); 8694 } 8695 } 8696 8697 state.result += charFromCodepoint(hexResult); 8698 8699 state.position++; 8700 8701 } else { 8702 throwError(state, 'unknown escape sequence'); 8703 } 8704 8705 captureStart = captureEnd = state.position; 8706 8707 } else if (is_EOL(ch)) { 8708 captureSegment(state, captureStart, captureEnd, true); 8709 writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent)); 8710 captureStart = captureEnd = state.position; 8711 8712 } else if (state.position === state.lineStart && testDocumentSeparator(state)) { 8713 throwError(state, 'unexpected end of the document within a double quoted scalar'); 8714 8715 } else { 8716 state.position++; 8717 captureEnd = state.position; 8718 } 8719 } 8720 8721 throwError(state, 'unexpected end of the stream within a double quoted scalar'); 8722 } 8723 8724 function readFlowCollection(state, nodeIndent) { 8725 var readNext = true, 8726 _line, 8727 _tag = state.tag, 8728 _result, 8729 _anchor = state.anchor, 8730 following, 8731 terminator, 8732 isPair, 8733 isExplicitPair, 8734 isMapping, 8735 keyNode, 8736 keyTag, 8737 valueNode, 8738 ch; 8739 8740 ch = state.input.charCodeAt(state.position); 8741 8742 if (ch === 0x5B/* [ */) { 8743 terminator = 0x5D;/* ] */ 8744 isMapping = false; 8745 _result = []; 8746 } else if (ch === 0x7B/* { */) { 8747 terminator = 0x7D;/* } */ 8748 isMapping = true; 8749 _result = {}; 8750 } else { 8751 return false; 8752 } 8753 8754 if (null !== state.anchor) { 8755 state.anchorMap[state.anchor] = _result; 8756 } 8757 8758 ch = state.input.charCodeAt(++state.position); 8759 8760 while (0 !== ch) { 8761 skipSeparationSpace(state, true, nodeIndent); 8762 8763 ch = state.input.charCodeAt(state.position); 8764 8765 if (ch === terminator) { 8766 state.position++; 8767 state.tag = _tag; 8768 state.anchor = _anchor; 8769 state.kind = isMapping ? 'mapping' : 'sequence'; 8770 state.result = _result; 8771 return true; 8772 } else if (!readNext) { 8773 throwError(state, 'missed comma between flow collection entries'); 8774 } 8775 8776 keyTag = keyNode = valueNode = null; 8777 isPair = isExplicitPair = false; 8778 8779 if (0x3F/* ? */ === ch) { 8780 following = state.input.charCodeAt(state.position + 1); 8781 8782 if (is_WS_OR_EOL(following)) { 8783 isPair = isExplicitPair = true; 8784 state.position++; 8785 skipSeparationSpace(state, true, nodeIndent); 8786 } 8787 } 8788 8789 _line = state.line; 8790 composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true); 8791 keyTag = state.tag; 8792 keyNode = state.result; 8793 skipSeparationSpace(state, true, nodeIndent); 8794 8795 ch = state.input.charCodeAt(state.position); 8796 8797 if ((isExplicitPair || state.line === _line) && 0x3A/* : */ === ch) { 8798 isPair = true; 8799 ch = state.input.charCodeAt(++state.position); 8800 skipSeparationSpace(state, true, nodeIndent); 8801 composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true); 8802 valueNode = state.result; 8803 } 8804 8805 if (isMapping) { 8806 storeMappingPair(state, _result, keyTag, keyNode, valueNode); 8807 } else if (isPair) { 8808 _result.push(storeMappingPair(state, null, keyTag, keyNode, valueNode)); 8809 } else { 8810 _result.push(keyNode); 8811 } 8812 8813 skipSeparationSpace(state, true, nodeIndent); 8814 8815 ch = state.input.charCodeAt(state.position); 8816 8817 if (0x2C/* , */ === ch) { 8818 readNext = true; 8819 ch = state.input.charCodeAt(++state.position); 8820 } else { 8821 readNext = false; 8822 } 8823 } 8824 8825 throwError(state, 'unexpected end of the stream within a flow collection'); 8826 } 8827 8828 function readBlockScalar(state, nodeIndent) { 8829 var captureStart, 8830 folding, 8831 chomping = CHOMPING_CLIP, 8832 detectedIndent = false, 8833 textIndent = nodeIndent, 8834 emptyLines = 0, 8835 atMoreIndented = false, 8836 tmp, 8837 ch; 8838 8839 ch = state.input.charCodeAt(state.position); 8840 8841 if (ch === 0x7C/* | */) { 8842 folding = false; 8843 } else if (ch === 0x3E/* > */) { 8844 folding = true; 8845 } else { 8846 return false; 8847 } 8848 8849 state.kind = 'scalar'; 8850 state.result = ''; 8851 8852 while (0 !== ch) { 8853 ch = state.input.charCodeAt(++state.position); 8854 8855 if (0x2B/* + */ === ch || 0x2D/* - */ === ch) { 8856 if (CHOMPING_CLIP === chomping) { 8857 chomping = (0x2B/* + */ === ch) ? CHOMPING_KEEP : CHOMPING_STRIP; 8858 } else { 8859 throwError(state, 'repeat of a chomping mode identifier'); 8860 } 8861 8862 } else if ((tmp = fromDecimalCode(ch)) >= 0) { 8863 if (tmp === 0) { 8864 throwError(state, 'bad explicit indentation width of a block scalar; it cannot be less than one'); 8865 } else if (!detectedIndent) { 8866 textIndent = nodeIndent + tmp - 1; 8867 detectedIndent = true; 8868 } else { 8869 throwError(state, 'repeat of an indentation width identifier'); 8870 } 8871 8872 } else { 8873 break; 8874 } 8875 } 8876 8877 if (is_WHITE_SPACE(ch)) { 8878 do { ch = state.input.charCodeAt(++state.position); } 8879 while (is_WHITE_SPACE(ch)); 8880 8881 if (0x23/* # */ === ch) { 8882 do { ch = state.input.charCodeAt(++state.position); } 8883 while (!is_EOL(ch) && (0 !== ch)); 8884 } 8885 } 8886 8887 while (0 !== ch) { 8888 readLineBreak(state); 8889 state.lineIndent = 0; 8890 8891 ch = state.input.charCodeAt(state.position); 8892 8893 while ((!detectedIndent || state.lineIndent < textIndent) && 8894 (0x20/* Space */ === ch)) { 8895 state.lineIndent++; 8896 ch = state.input.charCodeAt(++state.position); 8897 } 8898 8899 if (!detectedIndent && state.lineIndent > textIndent) { 8900 textIndent = state.lineIndent; 8901 } 8902 8903 if (is_EOL(ch)) { 8904 emptyLines++; 8905 continue; 8906 } 8907 8908 // End of the scalar. 8909 if (state.lineIndent < textIndent) { 8910 8911 // Perform the chomping. 8912 if (chomping === CHOMPING_KEEP) { 8913 state.result += common.repeat('\n', emptyLines); 8914 } else if (chomping === CHOMPING_CLIP) { 8915 if (detectedIndent) { // i.e. only if the scalar is not empty. 8916 state.result += '\n'; 8917 } 8918 } 8919 8920 // Break this `while` cycle and go to the funciton's epilogue. 8921 break; 8922 } 8923 8924 // Folded style: use fancy rules to handle line breaks. 8925 if (folding) { 8926 8927 // Lines starting with white space characters (more-indented lines) are not folded. 8928 if (is_WHITE_SPACE(ch)) { 8929 atMoreIndented = true; 8930 state.result += common.repeat('\n', emptyLines + 1); 8931 8932 // End of more-indented block. 8933 } else if (atMoreIndented) { 8934 atMoreIndented = false; 8935 state.result += common.repeat('\n', emptyLines + 1); 8936 8937 // Just one line break - perceive as the same line. 8938 } else if (0 === emptyLines) { 8939 if (detectedIndent) { // i.e. only if we have already read some scalar content. 8940 state.result += ' '; 8941 } 8942 8943 // Several line breaks - perceive as different lines. 8944 } else { 8945 state.result += common.repeat('\n', emptyLines); 8946 } 8947 8948 // Literal style: just add exact number of line breaks between content lines. 8949 } else if (detectedIndent) { 8950 // If current line isn't the first one - count line break from the last content line. 8951 state.result += common.repeat('\n', emptyLines + 1); 8952 } else { 8953 // In case of the first content line - count only empty lines. 8954 state.result += common.repeat('\n', emptyLines); 8955 } 8956 8957 detectedIndent = true; 8958 emptyLines = 0; 8959 captureStart = state.position; 8960 8961 while (!is_EOL(ch) && (0 !== ch)) { 8962 ch = state.input.charCodeAt(++state.position); 8963 } 8964 8965 captureSegment(state, captureStart, state.position, false); 8966 } 8967 8968 return true; 8969 } 8970 8971 function readBlockSequence(state, nodeIndent) { 8972 var _line, 8973 _tag = state.tag, 8974 _anchor = state.anchor, 8975 _result = [], 8976 following, 8977 detected = false, 8978 ch; 8979 8980 if (null !== state.anchor) { 8981 state.anchorMap[state.anchor] = _result; 8982 } 8983 8984 ch = state.input.charCodeAt(state.position); 8985 8986 while (0 !== ch) { 8987 8988 if (0x2D/* - */ !== ch) { 8989 break; 8990 } 8991 8992 following = state.input.charCodeAt(state.position + 1); 8993 8994 if (!is_WS_OR_EOL(following)) { 8995 break; 8996 } 8997 8998 detected = true; 8999 state.position++; 9000 9001 if (skipSeparationSpace(state, true, -1)) { 9002 if (state.lineIndent <= nodeIndent) { 9003 _result.push(null); 9004 ch = state.input.charCodeAt(state.position); 9005 continue; 9006 } 9007 } 9008 9009 _line = state.line; 9010 composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true); 9011 _result.push(state.result); 9012 skipSeparationSpace(state, true, -1); 9013 9014 ch = state.input.charCodeAt(state.position); 9015 9016 if ((state.line === _line || state.lineIndent > nodeIndent) && (0 !== ch)) { 9017 throwError(state, 'bad indentation of a sequence entry'); 9018 } else if (state.lineIndent < nodeIndent) { 9019 break; 9020 } 9021 } 9022 9023 if (detected) { 9024 state.tag = _tag; 9025 state.anchor = _anchor; 9026 state.kind = 'sequence'; 9027 state.result = _result; 9028 return true; 9029 } 9030 return false; 9031 } 9032 9033 function readBlockMapping(state, nodeIndent, flowIndent) { 9034 var following, 9035 allowCompact, 9036 _line, 9037 _tag = state.tag, 9038 _anchor = state.anchor, 9039 _result = {}, 9040 keyTag = null, 9041 keyNode = null, 9042 valueNode = null, 9043 atExplicitKey = false, 9044 detected = false, 9045 ch; 9046 9047 if (null !== state.anchor) { 9048 state.anchorMap[state.anchor] = _result; 9049 } 9050 9051 ch = state.input.charCodeAt(state.position); 9052 9053 while (0 !== ch) { 9054 following = state.input.charCodeAt(state.position + 1); 9055 _line = state.line; // Save the current line. 9056 9057 // 9058 // Explicit notation case. There are two separate blocks: 9059 // first for the key (denoted by "?") and second for the value (denoted by ":") 9060 // 9061 if ((0x3F/* ? */ === ch || 0x3A/* : */ === ch) && is_WS_OR_EOL(following)) { 9062 9063 if (0x3F/* ? */ === ch) { 9064 if (atExplicitKey) { 9065 storeMappingPair(state, _result, keyTag, keyNode, null); 9066 keyTag = keyNode = valueNode = null; 9067 } 9068 9069 detected = true; 9070 atExplicitKey = true; 9071 allowCompact = true; 9072 9073 } else if (atExplicitKey) { 9074 // i.e. 0x3A/* : */ === character after the explicit key. 9075 atExplicitKey = false; 9076 allowCompact = true; 9077 9078 } else { 9079 throwError(state, 'incomplete explicit mapping pair; a key node is missed'); 9080 } 9081 9082 state.position += 1; 9083 ch = following; 9084 9085 // 9086 // Implicit notation case. Flow-style node as the key first, then ":", and the value. 9087 // 9088 } else if (composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) { 9089 9090 if (state.line === _line) { 9091 ch = state.input.charCodeAt(state.position); 9092 9093 while (is_WHITE_SPACE(ch)) { 9094 ch = state.input.charCodeAt(++state.position); 9095 } 9096 9097 if (0x3A/* : */ === ch) { 9098 ch = state.input.charCodeAt(++state.position); 9099 9100 if (!is_WS_OR_EOL(ch)) { 9101 throwError(state, 'a whitespace character is expected after the key-value separator within a block mapping'); 9102 } 9103 9104 if (atExplicitKey) { 9105 storeMappingPair(state, _result, keyTag, keyNode, null); 9106 keyTag = keyNode = valueNode = null; 9107 } 9108 9109 detected = true; 9110 atExplicitKey = false; 9111 allowCompact = false; 9112 keyTag = state.tag; 9113 keyNode = state.result; 9114 9115 } else if (detected) { 9116 throwError(state, 'can not read an implicit mapping pair; a colon is missed'); 9117 9118 } else { 9119 state.tag = _tag; 9120 state.anchor = _anchor; 9121 return true; // Keep the result of `composeNode`. 9122 } 9123 9124 } else if (detected) { 9125 throwError(state, 'can not read a block mapping entry; a multiline key may not be an implicit key'); 9126 9127 } else { 9128 state.tag = _tag; 9129 state.anchor = _anchor; 9130 return true; // Keep the result of `composeNode`. 9131 } 9132 9133 } else { 9134 break; // Reading is done. Go to the epilogue. 9135 } 9136 9137 // 9138 // Common reading code for both explicit and implicit notations. 9139 // 9140 if (state.line === _line || state.lineIndent > nodeIndent) { 9141 if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) { 9142 if (atExplicitKey) { 9143 keyNode = state.result; 9144 } else { 9145 valueNode = state.result; 9146 } 9147 } 9148 9149 if (!atExplicitKey) { 9150 storeMappingPair(state, _result, keyTag, keyNode, valueNode); 9151 keyTag = keyNode = valueNode = null; 9152 } 9153 9154 skipSeparationSpace(state, true, -1); 9155 ch = state.input.charCodeAt(state.position); 9156 } 9157 9158 if (state.lineIndent > nodeIndent && (0 !== ch)) { 9159 throwError(state, 'bad indentation of a mapping entry'); 9160 } else if (state.lineIndent < nodeIndent) { 9161 break; 9162 } 9163 } 9164 9165 // 9166 // Epilogue. 9167 // 9168 9169 // Special case: last mapping's node contains only the key in explicit notation. 9170 if (atExplicitKey) { 9171 storeMappingPair(state, _result, keyTag, keyNode, null); 9172 } 9173 9174 // Expose the resulting mapping. 9175 if (detected) { 9176 state.tag = _tag; 9177 state.anchor = _anchor; 9178 state.kind = 'mapping'; 9179 state.result = _result; 9180 } 9181 9182 return detected; 9183 } 9184 9185 function readTagProperty(state) { 9186 var _position, 9187 isVerbatim = false, 9188 isNamed = false, 9189 tagHandle, 9190 tagName, 9191 ch; 9192 9193 ch = state.input.charCodeAt(state.position); 9194 9195 if (0x21/* ! */ !== ch) { 9196 return false; 9197 } 9198 9199 if (null !== state.tag) { 9200 throwError(state, 'duplication of a tag property'); 9201 } 9202 9203 ch = state.input.charCodeAt(++state.position); 9204 9205 if (0x3C/* < */ === ch) { 9206 isVerbatim = true; 9207 ch = state.input.charCodeAt(++state.position); 9208 9209 } else if (0x21/* ! */ === ch) { 9210 isNamed = true; 9211 tagHandle = '!!'; 9212 ch = state.input.charCodeAt(++state.position); 9213 9214 } else { 9215 tagHandle = '!'; 9216 } 9217 9218 _position = state.position; 9219 9220 if (isVerbatim) { 9221 do { ch = state.input.charCodeAt(++state.position); } 9222 while (0 !== ch && 0x3E/* > */ !== ch); 9223 9224 if (state.position < state.length) { 9225 tagName = state.input.slice(_position, state.position); 9226 ch = state.input.charCodeAt(++state.position); 9227 } else { 9228 throwError(state, 'unexpected end of the stream within a verbatim tag'); 9229 } 9230 } else { 9231 while (0 !== ch && !is_WS_OR_EOL(ch)) { 9232 9233 if (0x21/* ! */ === ch) { 9234 if (!isNamed) { 9235 tagHandle = state.input.slice(_position - 1, state.position + 1); 9236 9237 if (!PATTERN_TAG_HANDLE.test(tagHandle)) { 9238 throwError(state, 'named tag handle cannot contain such characters'); 9239 } 9240 9241 isNamed = true; 9242 _position = state.position + 1; 9243 } else { 9244 throwError(state, 'tag suffix cannot contain exclamation marks'); 9245 } 9246 } 9247 9248 ch = state.input.charCodeAt(++state.position); 9249 } 9250 9251 tagName = state.input.slice(_position, state.position); 9252 9253 if (PATTERN_FLOW_INDICATORS.test(tagName)) { 9254 throwError(state, 'tag suffix cannot contain flow indicator characters'); 9255 } 9256 } 9257 9258 if (tagName && !PATTERN_TAG_URI.test(tagName)) { 9259 throwError(state, 'tag name cannot contain such characters: ' + tagName); 9260 } 9261 9262 if (isVerbatim) { 9263 state.tag = tagName; 9264 9265 } else if (_hasOwnProperty.call(state.tagMap, tagHandle)) { 9266 state.tag = state.tagMap[tagHandle] + tagName; 9267 9268 } else if ('!' === tagHandle) { 9269 state.tag = '!' + tagName; 9270 9271 } else if ('!!' === tagHandle) { 9272 state.tag = 'tag:yaml.org,2002:' + tagName; 9273 9274 } else { 9275 throwError(state, 'undeclared tag handle "' + tagHandle + '"'); 9276 } 9277 9278 return true; 9279 } 9280 9281 function readAnchorProperty(state) { 9282 var _position, 9283 ch; 9284 9285 ch = state.input.charCodeAt(state.position); 9286 9287 if (0x26/* & */ !== ch) { 9288 return false; 9289 } 9290 9291 if (null !== state.anchor) { 9292 throwError(state, 'duplication of an anchor property'); 9293 } 9294 9295 ch = state.input.charCodeAt(++state.position); 9296 _position = state.position; 9297 9298 while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) { 9299 ch = state.input.charCodeAt(++state.position); 9300 } 9301 9302 if (state.position === _position) { 9303 throwError(state, 'name of an anchor node must contain at least one character'); 9304 } 9305 9306 state.anchor = state.input.slice(_position, state.position); 9307 return true; 9308 } 9309 9310 function readAlias(state) { 9311 var _position, alias, 9312 ch; 9313 9314 ch = state.input.charCodeAt(state.position); 9315 9316 if (0x2A/* * */ !== ch) { 9317 return false; 9318 } 9319 9320 ch = state.input.charCodeAt(++state.position); 9321 _position = state.position; 9322 9323 while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) { 9324 ch = state.input.charCodeAt(++state.position); 9325 } 9326 9327 if (state.position === _position) { 9328 throwError(state, 'name of an alias node must contain at least one character'); 9329 } 9330 9331 alias = state.input.slice(_position, state.position); 9332 9333 if (!state.anchorMap.hasOwnProperty(alias)) { 9334 throwError(state, 'unidentified alias "' + alias + '"'); 9335 } 9336 9337 state.result = state.anchorMap[alias]; 9338 skipSeparationSpace(state, true, -1); 9339 return true; 9340 } 9341 9342 function composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) { 9343 var allowBlockStyles, 9344 allowBlockScalars, 9345 allowBlockCollections, 9346 indentStatus = 1, // 1: this>parent, 0: this=parent, -1: this<parent 9347 atNewLine = false, 9348 hasContent = false, 9349 typeIndex, 9350 typeQuantity, 9351 type, 9352 flowIndent, 9353 blockIndent; 9354 9355 state.tag = null; 9356 state.anchor = null; 9357 state.kind = null; 9358 state.result = null; 9359 9360 allowBlockStyles = allowBlockScalars = allowBlockCollections = 9361 CONTEXT_BLOCK_OUT === nodeContext || 9362 CONTEXT_BLOCK_IN === nodeContext; 9363 9364 if (allowToSeek) { 9365 if (skipSeparationSpace(state, true, -1)) { 9366 atNewLine = true; 9367 9368 if (state.lineIndent > parentIndent) { 9369 indentStatus = 1; 9370 } else if (state.lineIndent === parentIndent) { 9371 indentStatus = 0; 9372 } else if (state.lineIndent < parentIndent) { 9373 indentStatus = -1; 9374 } 9375 } 9376 } 9377 9378 if (1 === indentStatus) { 9379 while (readTagProperty(state) || readAnchorProperty(state)) { 9380 if (skipSeparationSpace(state, true, -1)) { 9381 atNewLine = true; 9382 allowBlockCollections = allowBlockStyles; 9383 9384 if (state.lineIndent > parentIndent) { 9385 indentStatus = 1; 9386 } else if (state.lineIndent === parentIndent) { 9387 indentStatus = 0; 9388 } else if (state.lineIndent < parentIndent) { 9389 indentStatus = -1; 9390 } 9391 } else { 9392 allowBlockCollections = false; 9393 } 9394 } 9395 } 9396 9397 if (allowBlockCollections) { 9398 allowBlockCollections = atNewLine || allowCompact; 9399 } 9400 9401 if (1 === indentStatus || CONTEXT_BLOCK_OUT === nodeContext) { 9402 if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) { 9403 flowIndent = parentIndent; 9404 } else { 9405 flowIndent = parentIndent + 1; 9406 } 9407 9408 blockIndent = state.position - state.lineStart; 9409 9410 if (1 === indentStatus) { 9411 if (allowBlockCollections && 9412 (readBlockSequence(state, blockIndent) || 9413 readBlockMapping(state, blockIndent, flowIndent)) || 9414 readFlowCollection(state, flowIndent)) { 9415 hasContent = true; 9416 } else { 9417 if ((allowBlockScalars && readBlockScalar(state, flowIndent)) || 9418 readSingleQuotedScalar(state, flowIndent) || 9419 readDoubleQuotedScalar(state, flowIndent)) { 9420 hasContent = true; 9421 9422 } else if (readAlias(state)) { 9423 hasContent = true; 9424 9425 if (null !== state.tag || null !== state.anchor) { 9426 throwError(state, 'alias node should not have any properties'); 9427 } 9428 9429 } else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) { 9430 hasContent = true; 9431 9432 if (null === state.tag) { 9433 state.tag = '?'; 9434 } 9435 } 9436 9437 if (null !== state.anchor) { 9438 state.anchorMap[state.anchor] = state.result; 9439 } 9440 } 9441 } else if (0 === indentStatus) { 9442 // Special case: block sequences are allowed to have same indentation level as the parent. 9443 // http://www.yaml.org/spec/1.2/spec.html#id2799784 9444 hasContent = allowBlockCollections && readBlockSequence(state, blockIndent); 9445 } 9446 } 9447 9448 if (null !== state.tag && '!' !== state.tag) { 9449 if ('?' === state.tag) { 9450 for (typeIndex = 0, typeQuantity = state.implicitTypes.length; 9451 typeIndex < typeQuantity; 9452 typeIndex += 1) { 9453 type = state.implicitTypes[typeIndex]; 9454 9455 // Implicit resolving is not allowed for non-scalar types, and '?' 9456 // non-specific tag is only assigned to plain scalars. So, it isn't 9457 // needed to check for 'kind' conformity. 9458 9459 if (type.resolve(state.result)) { // `state.result` updated in resolver if matched 9460 state.result = type.construct(state.result); 9461 state.tag = type.tag; 9462 if (null !== state.anchor) { 9463 state.anchorMap[state.anchor] = state.result; 9464 } 9465 break; 9466 } 9467 } 9468 } else if (_hasOwnProperty.call(state.typeMap, state.tag)) { 9469 type = state.typeMap[state.tag]; 9470 9471 if (null !== state.result && type.kind !== state.kind) { 9472 throwError(state, 'unacceptable node kind for !<' + state.tag + '> tag; it should be "' + type.kind + '", not "' + state.kind + '"'); 9473 } 9474 9475 if (!type.resolve(state.result)) { // `state.result` updated in resolver if matched 9476 throwError(state, 'cannot resolve a node with !<' + state.tag + '> explicit tag'); 9477 } else { 9478 state.result = type.construct(state.result); 9479 if (null !== state.anchor) { 9480 state.anchorMap[state.anchor] = state.result; 9481 } 9482 } 9483 } else { 9484 throwError(state, 'unknown tag !<' + state.tag + '>'); 9485 } 9486 } 9487 9488 return null !== state.tag || null !== state.anchor || hasContent; 9489 } 9490 9491 function readDocument(state) { 9492 var documentStart = state.position, 9493 _position, 9494 directiveName, 9495 directiveArgs, 9496 hasDirectives = false, 9497 ch; 9498 9499 state.version = null; 9500 state.checkLineBreaks = state.legacy; 9501 state.tagMap = {}; 9502 state.anchorMap = {}; 9503 9504 while (0 !== (ch = state.input.charCodeAt(state.position))) { 9505 skipSeparationSpace(state, true, -1); 9506 9507 ch = state.input.charCodeAt(state.position); 9508 9509 if (state.lineIndent > 0 || 0x25/* % */ !== ch) { 9510 break; 9511 } 9512 9513 hasDirectives = true; 9514 ch = state.input.charCodeAt(++state.position); 9515 _position = state.position; 9516 9517 while (0 !== ch && !is_WS_OR_EOL(ch)) { 9518 ch = state.input.charCodeAt(++state.position); 9519 } 9520 9521 directiveName = state.input.slice(_position, state.position); 9522 directiveArgs = []; 9523 9524 if (directiveName.length < 1) { 9525 throwError(state, 'directive name must not be less than one character in length'); 9526 } 9527 9528 while (0 !== ch) { 9529 while (is_WHITE_SPACE(ch)) { 9530 ch = state.input.charCodeAt(++state.position); 9531 } 9532 9533 if (0x23/* # */ === ch) { 9534 do { ch = state.input.charCodeAt(++state.position); } 9535 while (0 !== ch && !is_EOL(ch)); 9536 break; 9537 } 9538 9539 if (is_EOL(ch)) { 9540 break; 9541 } 9542 9543 _position = state.position; 9544 9545 while (0 !== ch && !is_WS_OR_EOL(ch)) { 9546 ch = state.input.charCodeAt(++state.position); 9547 } 9548 9549 directiveArgs.push(state.input.slice(_position, state.position)); 9550 } 9551 9552 if (0 !== ch) { 9553 readLineBreak(state); 9554 } 9555 9556 if (_hasOwnProperty.call(directiveHandlers, directiveName)) { 9557 directiveHandlers[directiveName](state, directiveName, directiveArgs); 9558 } else { 9559 throwWarning(state, 'unknown document directive "' + directiveName + '"'); 9560 } 9561 } 9562 9563 skipSeparationSpace(state, true, -1); 9564 9565 if (0 === state.lineIndent && 9566 0x2D/* - */ === state.input.charCodeAt(state.position) && 9567 0x2D/* - */ === state.input.charCodeAt(state.position + 1) && 9568 0x2D/* - */ === state.input.charCodeAt(state.position + 2)) { 9569 state.position += 3; 9570 skipSeparationSpace(state, true, -1); 9571 9572 } else if (hasDirectives) { 9573 throwError(state, 'directives end mark is expected'); 9574 } 9575 9576 composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true); 9577 skipSeparationSpace(state, true, -1); 9578 9579 if (state.checkLineBreaks && 9580 PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) { 9581 throwWarning(state, 'non-ASCII line breaks are interpreted as content'); 9582 } 9583 9584 state.documents.push(state.result); 9585 9586 if (state.position === state.lineStart && testDocumentSeparator(state)) { 9587 9588 if (0x2E/* . */ === state.input.charCodeAt(state.position)) { 9589 state.position += 3; 9590 skipSeparationSpace(state, true, -1); 9591 } 9592 return; 9593 } 9594 9595 if (state.position < (state.length - 1)) { 9596 throwError(state, 'end of the stream or a document separator is expected'); 9597 } else { 9598 return; 9599 } 9600 } 9601 9602 9603 function loadDocuments(input, options) { 9604 input = String(input); 9605 options = options || {}; 9606 9607 if (input.length !== 0) { 9608 9609 // Add tailing `\n` if not exists 9610 if (0x0A/* LF */ !== input.charCodeAt(input.length - 1) && 9611 0x0D/* CR */ !== input.charCodeAt(input.length - 1)) { 9612 input += '\n'; 9613 } 9614 9615 // Strip BOM 9616 if (input.charCodeAt(0) === 0xFEFF) { 9617 input = input.slice(1); 9618 } 9619 } 9620 9621 var state = new State(input, options); 9622 9623 // Use 0 as string terminator. That significantly simplifies bounds check. 9624 state.input += '\0'; 9625 9626 while (0x20/* Space */ === state.input.charCodeAt(state.position)) { 9627 state.lineIndent += 1; 9628 state.position += 1; 9629 } 9630 9631 while (state.position < (state.length - 1)) { 9632 readDocument(state); 9633 } 9634 9635 return state.documents; 9636 } 9637 9638 9639 function loadAll(input, iterator, options) { 9640 var documents = loadDocuments(input, options), index, length; 9641 9642 for (index = 0, length = documents.length; index < length; index += 1) { 9643 iterator(documents[index]); 9644 } 9645 } 9646 9647 9648 function load(input, options) { 9649 var documents = loadDocuments(input, options); 9650 9651 if (0 === documents.length) { 9652 /*eslint-disable no-undefined*/ 9653 return undefined; 9654 } else if (1 === documents.length) { 9655 return documents[0]; 9656 } 9657 throw new YAMLException('expected a single document in the stream, but found more'); 9658 } 9659 9660 9661 function safeLoadAll(input, output, options) { 9662 loadAll(input, output, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options)); 9663 } 9664 9665 9666 function safeLoad(input, options) { 9667 return load(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options)); 9668 } 9669 9670 9671 module.exports.loadAll = loadAll; 9672 module.exports.load = load; 9673 module.exports.safeLoadAll = safeLoadAll; 9674 module.exports.safeLoad = safeLoad; 9675 9676 },{"./common":22,"./exception":24,"./mark":26,"./schema/default_full":29,"./schema/default_safe":30}],26:[function(require,module,exports){ 9677 'use strict'; 9678 9679 9680 var common = require('./common'); 9681 9682 9683 function Mark(name, buffer, position, line, column) { 9684 this.name = name; 9685 this.buffer = buffer; 9686 this.position = position; 9687 this.line = line; 9688 this.column = column; 9689 } 9690 9691 9692 Mark.prototype.getSnippet = function getSnippet(indent, maxLength) { 9693 var head, start, tail, end, snippet; 9694 9695 if (!this.buffer) { 9696 return null; 9697 } 9698 9699 indent = indent || 4; 9700 maxLength = maxLength || 75; 9701 9702 head = ''; 9703 start = this.position; 9704 9705 while (start > 0 && -1 === '\x00\r\n\x85\u2028\u2029'.indexOf(this.buffer.charAt(start - 1))) { 9706 start -= 1; 9707 if (this.position - start > (maxLength / 2 - 1)) { 9708 head = ' ... '; 9709 start += 5; 9710 break; 9711 } 9712 } 9713 9714 tail = ''; 9715 end = this.position; 9716 9717 while (end < this.buffer.length && -1 === '\x00\r\n\x85\u2028\u2029'.indexOf(this.buffer.charAt(end))) { 9718 end += 1; 9719 if (end - this.position > (maxLength / 2 - 1)) { 9720 tail = ' ... '; 9721 end -= 5; 9722 break; 9723 } 9724 } 9725 9726 snippet = this.buffer.slice(start, end); 9727 9728 return common.repeat(' ', indent) + head + snippet + tail + '\n' + 9729 common.repeat(' ', indent + this.position - start + head.length) + '^'; 9730 }; 9731 9732 9733 Mark.prototype.toString = function toString(compact) { 9734 var snippet, where = ''; 9735 9736 if (this.name) { 9737 where += 'in "' + this.name + '" '; 9738 } 9739 9740 where += 'at line ' + (this.line + 1) + ', column ' + (this.column + 1); 9741 9742 if (!compact) { 9743 snippet = this.getSnippet(); 9744 9745 if (snippet) { 9746 where += ':\n' + snippet; 9747 } 9748 } 9749 9750 return where; 9751 }; 9752 9753 9754 module.exports = Mark; 9755 9756 },{"./common":22}],27:[function(require,module,exports){ 9757 'use strict'; 9758 9759 /*eslint-disable max-len*/ 9760 9761 var common = require('./common'); 9762 var YAMLException = require('./exception'); 9763 var Type = require('./type'); 9764 9765 9766 function compileList(schema, name, result) { 9767 var exclude = []; 9768 9769 schema.include.forEach(function (includedSchema) { 9770 result = compileList(includedSchema, name, result); 9771 }); 9772 9773 schema[name].forEach(function (currentType) { 9774 result.forEach(function (previousType, previousIndex) { 9775 if (previousType.tag === currentType.tag) { 9776 exclude.push(previousIndex); 9777 } 9778 }); 9779 9780 result.push(currentType); 9781 }); 9782 9783 return result.filter(function (type, index) { 9784 return -1 === exclude.indexOf(index); 9785 }); 9786 } 9787 9788 9789 function compileMap(/* lists... */) { 9790 var result = {}, index, length; 9791 9792 function collectType(type) { 9793 result[type.tag] = type; 9794 } 9795 9796 for (index = 0, length = arguments.length; index < length; index += 1) { 9797 arguments[index].forEach(collectType); 9798 } 9799 9800 return result; 9801 } 9802 9803 9804 function Schema(definition) { 9805 this.include = definition.include || []; 9806 this.implicit = definition.implicit || []; 9807 this.explicit = definition.explicit || []; 9808 9809 this.implicit.forEach(function (type) { 9810 if (type.loadKind && 'scalar' !== type.loadKind) { 9811 throw new YAMLException('There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.'); 9812 } 9813 }); 9814 9815 this.compiledImplicit = compileList(this, 'implicit', []); 9816 this.compiledExplicit = compileList(this, 'explicit', []); 9817 this.compiledTypeMap = compileMap(this.compiledImplicit, this.compiledExplicit); 9818 } 9819 9820 9821 Schema.DEFAULT = null; 9822 9823 9824 Schema.create = function createSchema() { 9825 var schemas, types; 9826 9827 switch (arguments.length) { 9828 case 1: 9829 schemas = Schema.DEFAULT; 9830 types = arguments[0]; 9831 break; 9832 9833 case 2: 9834 schemas = arguments[0]; 9835 types = arguments[1]; 9836 break; 9837 9838 default: 9839 throw new YAMLException('Wrong number of arguments for Schema.create function'); 9840 } 9841 9842 schemas = common.toArray(schemas); 9843 types = common.toArray(types); 9844 9845 if (!schemas.every(function (schema) { return schema instanceof Schema; })) { 9846 throw new YAMLException('Specified list of super schemas (or a single Schema object) contains a non-Schema object.'); 9847 } 9848 9849 if (!types.every(function (type) { return type instanceof Type; })) { 9850 throw new YAMLException('Specified list of YAML types (or a single Type object) contains a non-Type object.'); 9851 } 9852 9853 return new Schema({ 9854 include: schemas, 9855 explicit: types 9856 }); 9857 }; 9858 9859 9860 module.exports = Schema; 9861 9862 },{"./common":22,"./exception":24,"./type":33}],28:[function(require,module,exports){ 9863 // Standard YAML's Core schema. 9864 // http://www.yaml.org/spec/1.2/spec.html#id2804923 9865 // 9866 // NOTE: JS-YAML does not support schema-specific tag resolution restrictions. 9867 // So, Core schema has no distinctions from JSON schema is JS-YAML. 9868 9869 9870 'use strict'; 9871 9872 9873 var Schema = require('../schema'); 9874 9875 9876 module.exports = new Schema({ 9877 include: [ 9878 require('./json') 9879 ] 9880 }); 9881 9882 },{"../schema":27,"./json":32}],29:[function(require,module,exports){ 9883 // JS-YAML's default schema for `load` function. 9884 // It is not described in the YAML specification. 9885 // 9886 // This schema is based on JS-YAML's default safe schema and includes 9887 // JavaScript-specific types: !!js/undefined, !!js/regexp and !!js/function. 9888 // 9889 // Also this schema is used as default base schema at `Schema.create` function. 9890 9891 9892 'use strict'; 9893 9894 9895 var Schema = require('../schema'); 9896 9897 9898 module.exports = Schema.DEFAULT = new Schema({ 9899 include: [ 9900 require('./default_safe') 9901 ], 9902 explicit: [ 9903 require('../type/js/undefined'), 9904 require('../type/js/regexp'), 9905 require('../type/js/function') 9906 ] 9907 }); 9908 9909 },{"../schema":27,"../type/js/function":38,"../type/js/regexp":39,"../type/js/undefined":40,"./default_safe":30}],30:[function(require,module,exports){ 9910 // JS-YAML's default schema for `safeLoad` function. 9911 // It is not described in the YAML specification. 9912 // 9913 // This schema is based on standard YAML's Core schema and includes most of 9914 // extra types described at YAML tag repository. (http://yaml.org/type/) 9915 9916 9917 'use strict'; 9918 9919 9920 var Schema = require('../schema'); 9921 9922 9923 module.exports = new Schema({ 9924 include: [ 9925 require('./core') 9926 ], 9927 implicit: [ 9928 require('../type/timestamp'), 9929 require('../type/merge') 9930 ], 9931 explicit: [ 9932 require('../type/binary'), 9933 require('../type/omap'), 9934 require('../type/pairs'), 9935 require('../type/set') 9936 ] 9937 }); 9938 9939 },{"../schema":27,"../type/binary":34,"../type/merge":42,"../type/omap":44,"../type/pairs":45,"../type/set":47,"../type/timestamp":49,"./core":28}],31:[function(require,module,exports){ 9940 // Standard YAML's Failsafe schema. 9941 // http://www.yaml.org/spec/1.2/spec.html#id2802346 9942 9943 9944 'use strict'; 9945 9946 9947 var Schema = require('../schema'); 9948 9949 9950 module.exports = new Schema({ 9951 explicit: [ 9952 require('../type/str'), 9953 require('../type/seq'), 9954 require('../type/map') 9955 ] 9956 }); 9957 9958 },{"../schema":27,"../type/map":41,"../type/seq":46,"../type/str":48}],32:[function(require,module,exports){ 9959 // Standard YAML's JSON schema. 9960 // http://www.yaml.org/spec/1.2/spec.html#id2803231 9961 // 9962 // NOTE: JS-YAML does not support schema-specific tag resolution restrictions. 9963 // So, this schema is not such strict as defined in the YAML specification. 9964 // It allows numbers in binary notaion, use `Null` and `NULL` as `null`, etc. 9965 9966 9967 'use strict'; 9968 9969 9970 var Schema = require('../schema'); 9971 9972 9973 module.exports = new Schema({ 9974 include: [ 9975 require('./failsafe') 9976 ], 9977 implicit: [ 9978 require('../type/null'), 9979 require('../type/bool'), 9980 require('../type/int'), 9981 require('../type/float') 9982 ] 9983 }); 9984 9985 },{"../schema":27,"../type/bool":35,"../type/float":36,"../type/int":37,"../type/null":43,"./failsafe":31}],33:[function(require,module,exports){ 9986 'use strict'; 9987 9988 var YAMLException = require('./exception'); 9989 9990 var TYPE_CONSTRUCTOR_OPTIONS = [ 9991 'kind', 9992 'resolve', 9993 'construct', 9994 'instanceOf', 9995 'predicate', 9996 'represent', 9997 'defaultStyle', 9998 'styleAliases' 9999 ]; 10000 10001 var YAML_NODE_KINDS = [ 10002 'scalar', 10003 'sequence', 10004 'mapping' 10005 ]; 10006 10007 function compileStyleAliases(map) { 10008 var result = {}; 10009 10010 if (null !== map) { 10011 Object.keys(map).forEach(function (style) { 10012 map[style].forEach(function (alias) { 10013 result[String(alias)] = style; 10014 }); 10015 }); 10016 } 10017 10018 return result; 10019 } 10020 10021 function Type(tag, options) { 10022 options = options || {}; 10023 10024 Object.keys(options).forEach(function (name) { 10025 if (-1 === TYPE_CONSTRUCTOR_OPTIONS.indexOf(name)) { 10026 throw new YAMLException('Unknown option "' + name + '" is met in definition of "' + tag + '" YAML type.'); 10027 } 10028 }); 10029 10030 // TODO: Add tag format check. 10031 this.tag = tag; 10032 this.kind = options['kind'] || null; 10033 this.resolve = options['resolve'] || function () { return true; }; 10034 this.construct = options['construct'] || function (data) { return data; }; 10035 this.instanceOf = options['instanceOf'] || null; 10036 this.predicate = options['predicate'] || null; 10037 this.represent = options['represent'] || null; 10038 this.defaultStyle = options['defaultStyle'] || null; 10039 this.styleAliases = compileStyleAliases(options['styleAliases'] || null); 10040 10041 if (-1 === YAML_NODE_KINDS.indexOf(this.kind)) { 10042 throw new YAMLException('Unknown kind "' + this.kind + '" is specified for "' + tag + '" YAML type.'); 10043 } 10044 } 10045 10046 module.exports = Type; 10047 10048 },{"./exception":24}],34:[function(require,module,exports){ 10049 'use strict'; 10050 10051 /*eslint-disable no-bitwise*/ 10052 10053 // A trick for browserified version. 10054 // Since we make browserifier to ignore `buffer` module, NodeBuffer will be undefined 10055 var NodeBuffer = require('buffer').Buffer; 10056 var Type = require('../type'); 10057 10058 10059 // [ 64, 65, 66 ] -> [ padding, CR, LF ] 10060 var BASE64_MAP = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\n\r'; 10061 10062 10063 function resolveYamlBinary(data) { 10064 if (null === data) { 10065 return false; 10066 } 10067 10068 var code, idx, bitlen = 0, max = data.length, map = BASE64_MAP; 10069 10070 // Convert one by one. 10071 for (idx = 0; idx < max; idx++) { 10072 code = map.indexOf(data.charAt(idx)); 10073 10074 // Skip CR/LF 10075 if (code > 64) { continue; } 10076 10077 // Fail on illegal characters 10078 if (code < 0) { return false; } 10079 10080 bitlen += 6; 10081 } 10082 10083 // If there are any bits left, source was corrupted 10084 return (bitlen % 8) === 0; 10085 } 10086 10087 function constructYamlBinary(data) { 10088 var idx, tailbits, 10089 input = data.replace(/[\r\n=]/g, ''), // remove CR/LF & padding to simplify scan 10090 max = input.length, 10091 map = BASE64_MAP, 10092 bits = 0, 10093 result = []; 10094 10095 // Collect by 6*4 bits (3 bytes) 10096 10097 for (idx = 0; idx < max; idx++) { 10098 if ((idx % 4 === 0) && idx) { 10099 result.push((bits >> 16) & 0xFF); 10100 result.push((bits >> 8) & 0xFF); 10101 result.push(bits & 0xFF); 10102 } 10103 10104 bits = (bits << 6) | map.indexOf(input.charAt(idx)); 10105 } 10106 10107 // Dump tail 10108 10109 tailbits = (max % 4) * 6; 10110 10111 if (tailbits === 0) { 10112 result.push((bits >> 16) & 0xFF); 10113 result.push((bits >> 8) & 0xFF); 10114 result.push(bits & 0xFF); 10115 } else if (tailbits === 18) { 10116 result.push((bits >> 10) & 0xFF); 10117 result.push((bits >> 2) & 0xFF); 10118 } else if (tailbits === 12) { 10119 result.push((bits >> 4) & 0xFF); 10120 } 10121 10122 // Wrap into Buffer for NodeJS and leave Array for browser 10123 if (NodeBuffer) { 10124 return new NodeBuffer(result); 10125 } 10126 10127 return result; 10128 } 10129 10130 function representYamlBinary(object /*, style*/) { 10131 var result = '', bits = 0, idx, tail, 10132 max = object.length, 10133 map = BASE64_MAP; 10134 10135 // Convert every three bytes to 4 ASCII characters. 10136 10137 for (idx = 0; idx < max; idx++) { 10138 if ((idx % 3 === 0) && idx) { 10139 result += map[(bits >> 18) & 0x3F]; 10140 result += map[(bits >> 12) & 0x3F]; 10141 result += map[(bits >> 6) & 0x3F]; 10142 result += map[bits & 0x3F]; 10143 } 10144 10145 bits = (bits << 8) + object[idx]; 10146 } 10147 10148 // Dump tail 10149 10150 tail = max % 3; 10151 10152 if (tail === 0) { 10153 result += map[(bits >> 18) & 0x3F]; 10154 result += map[(bits >> 12) & 0x3F]; 10155 result += map[(bits >> 6) & 0x3F]; 10156 result += map[bits & 0x3F]; 10157 } else if (tail === 2) { 10158 result += map[(bits >> 10) & 0x3F]; 10159 result += map[(bits >> 4) & 0x3F]; 10160 result += map[(bits << 2) & 0x3F]; 10161 result += map[64]; 10162 } else if (tail === 1) { 10163 result += map[(bits >> 2) & 0x3F]; 10164 result += map[(bits << 4) & 0x3F]; 10165 result += map[64]; 10166 result += map[64]; 10167 } 10168 10169 return result; 10170 } 10171 10172 function isBinary(object) { 10173 return NodeBuffer && NodeBuffer.isBuffer(object); 10174 } 10175 10176 module.exports = new Type('tag:yaml.org,2002:binary', { 10177 kind: 'scalar', 10178 resolve: resolveYamlBinary, 10179 construct: constructYamlBinary, 10180 predicate: isBinary, 10181 represent: representYamlBinary 10182 }); 10183 10184 },{"../type":33,"buffer":12}],35:[function(require,module,exports){ 10185 'use strict'; 10186 10187 var Type = require('../type'); 10188 10189 function resolveYamlBoolean(data) { 10190 if (null === data) { 10191 return false; 10192 } 10193 10194 var max = data.length; 10195 10196 return (max === 4 && (data === 'true' || data === 'True' || data === 'TRUE')) || 10197 (max === 5 && (data === 'false' || data === 'False' || data === 'FALSE')); 10198 } 10199 10200 function constructYamlBoolean(data) { 10201 return data === 'true' || 10202 data === 'True' || 10203 data === 'TRUE'; 10204 } 10205 10206 function isBoolean(object) { 10207 return '[object Boolean]' === Object.prototype.toString.call(object); 10208 } 10209 10210 module.exports = new Type('tag:yaml.org,2002:bool', { 10211 kind: 'scalar', 10212 resolve: resolveYamlBoolean, 10213 construct: constructYamlBoolean, 10214 predicate: isBoolean, 10215 represent: { 10216 lowercase: function (object) { return object ? 'true' : 'false'; }, 10217 uppercase: function (object) { return object ? 'TRUE' : 'FALSE'; }, 10218 camelcase: function (object) { return object ? 'True' : 'False'; } 10219 }, 10220 defaultStyle: 'lowercase' 10221 }); 10222 10223 },{"../type":33}],36:[function(require,module,exports){ 10224 'use strict'; 10225 10226 var common = require('../common'); 10227 var Type = require('../type'); 10228 10229 var YAML_FLOAT_PATTERN = new RegExp( 10230 '^(?:[-+]?(?:[0-9][0-9_]*)\\.[0-9_]*(?:[eE][-+][0-9]+)?' + 10231 '|\\.[0-9_]+(?:[eE][-+][0-9]+)?' + 10232 '|[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+\\.[0-9_]*' + 10233 '|[-+]?\\.(?:inf|Inf|INF)' + 10234 '|\\.(?:nan|NaN|NAN))$'); 10235 10236 function resolveYamlFloat(data) { 10237 if (null === data) { 10238 return false; 10239 } 10240 10241 if (!YAML_FLOAT_PATTERN.test(data)) { 10242 return false; 10243 } 10244 return true; 10245 } 10246 10247 function constructYamlFloat(data) { 10248 var value, sign, base, digits; 10249 10250 value = data.replace(/_/g, '').toLowerCase(); 10251 sign = '-' === value[0] ? -1 : 1; 10252 digits = []; 10253 10254 if (0 <= '+-'.indexOf(value[0])) { 10255 value = value.slice(1); 10256 } 10257 10258 if ('.inf' === value) { 10259 return (1 === sign) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY; 10260 10261 } else if ('.nan' === value) { 10262 return NaN; 10263 10264 } else if (0 <= value.indexOf(':')) { 10265 value.split(':').forEach(function (v) { 10266 digits.unshift(parseFloat(v, 10)); 10267 }); 10268 10269 value = 0.0; 10270 base = 1; 10271 10272 digits.forEach(function (d) { 10273 value += d * base; 10274 base *= 60; 10275 }); 10276 10277 return sign * value; 10278 10279 } 10280 return sign * parseFloat(value, 10); 10281 } 10282 10283 10284 var SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/; 10285 10286 function representYamlFloat(object, style) { 10287 var res; 10288 10289 if (isNaN(object)) { 10290 switch (style) { 10291 case 'lowercase': 10292 return '.nan'; 10293 case 'uppercase': 10294 return '.NAN'; 10295 case 'camelcase': 10296 return '.NaN'; 10297 } 10298 } else if (Number.POSITIVE_INFINITY === object) { 10299 switch (style) { 10300 case 'lowercase': 10301 return '.inf'; 10302 case 'uppercase': 10303 return '.INF'; 10304 case 'camelcase': 10305 return '.Inf'; 10306 } 10307 } else if (Number.NEGATIVE_INFINITY === object) { 10308 switch (style) { 10309 case 'lowercase': 10310 return '-.inf'; 10311 case 'uppercase': 10312 return '-.INF'; 10313 case 'camelcase': 10314 return '-.Inf'; 10315 } 10316 } else if (common.isNegativeZero(object)) { 10317 return '-0.0'; 10318 } 10319 10320 res = object.toString(10); 10321 10322 // JS stringifier can build scientific format without dots: 5e-100, 10323 // while YAML requres dot: 5.e-100. Fix it with simple hack 10324 10325 return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace('e', '.e') : res; 10326 } 10327 10328 function isFloat(object) { 10329 return ('[object Number]' === Object.prototype.toString.call(object)) && 10330 (0 !== object % 1 || common.isNegativeZero(object)); 10331 } 10332 10333 module.exports = new Type('tag:yaml.org,2002:float', { 10334 kind: 'scalar', 10335 resolve: resolveYamlFloat, 10336 construct: constructYamlFloat, 10337 predicate: isFloat, 10338 represent: representYamlFloat, 10339 defaultStyle: 'lowercase' 10340 }); 10341 10342 },{"../common":22,"../type":33}],37:[function(require,module,exports){ 10343 'use strict'; 10344 10345 var common = require('../common'); 10346 var Type = require('../type'); 10347 10348 function isHexCode(c) { 10349 return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) || 10350 ((0x41/* A */ <= c) && (c <= 0x46/* F */)) || 10351 ((0x61/* a */ <= c) && (c <= 0x66/* f */)); 10352 } 10353 10354 function isOctCode(c) { 10355 return ((0x30/* 0 */ <= c) && (c <= 0x37/* 7 */)); 10356 } 10357 10358 function isDecCode(c) { 10359 return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)); 10360 } 10361 10362 function resolveYamlInteger(data) { 10363 if (null === data) { 10364 return false; 10365 } 10366 10367 var max = data.length, 10368 index = 0, 10369 hasDigits = false, 10370 ch; 10371 10372 if (!max) { return false; } 10373 10374 ch = data[index]; 10375 10376 // sign 10377 if (ch === '-' || ch === '+') { 10378 ch = data[++index]; 10379 } 10380 10381 if (ch === '0') { 10382 // 0 10383 if (index + 1 === max) { return true; } 10384 ch = data[++index]; 10385 10386 // base 2, base 8, base 16 10387 10388 if (ch === 'b') { 10389 // base 2 10390 index++; 10391 10392 for (; index < max; index++) { 10393 ch = data[index]; 10394 if (ch === '_') { continue; } 10395 if (ch !== '0' && ch !== '1') { 10396 return false; 10397 } 10398 hasDigits = true; 10399 } 10400 return hasDigits; 10401 } 10402 10403 10404 if (ch === 'x') { 10405 // base 16 10406 index++; 10407 10408 for (; index < max; index++) { 10409 ch = data[index]; 10410 if (ch === '_') { continue; } 10411 if (!isHexCode(data.charCodeAt(index))) { 10412 return false; 10413 } 10414 hasDigits = true; 10415 } 10416 return hasDigits; 10417 } 10418 10419 // base 8 10420 for (; index < max; index++) { 10421 ch = data[index]; 10422 if (ch === '_') { continue; } 10423 if (!isOctCode(data.charCodeAt(index))) { 10424 return false; 10425 } 10426 hasDigits = true; 10427 } 10428 return hasDigits; 10429 } 10430 10431 // base 10 (except 0) or base 60 10432 10433 for (; index < max; index++) { 10434 ch = data[index]; 10435 if (ch === '_') { continue; } 10436 if (ch === ':') { break; } 10437 if (!isDecCode(data.charCodeAt(index))) { 10438 return false; 10439 } 10440 hasDigits = true; 10441 } 10442 10443 if (!hasDigits) { return false; } 10444 10445 // if !base60 - done; 10446 if (ch !== ':') { return true; } 10447 10448 // base60 almost not used, no needs to optimize 10449 return /^(:[0-5]?[0-9])+$/.test(data.slice(index)); 10450 } 10451 10452 function constructYamlInteger(data) { 10453 var value = data, sign = 1, ch, base, digits = []; 10454 10455 if (value.indexOf('_') !== -1) { 10456 value = value.replace(/_/g, ''); 10457 } 10458 10459 ch = value[0]; 10460 10461 if (ch === '-' || ch === '+') { 10462 if (ch === '-') { sign = -1; } 10463 value = value.slice(1); 10464 ch = value[0]; 10465 } 10466 10467 if ('0' === value) { 10468 return 0; 10469 } 10470 10471 if (ch === '0') { 10472 if (value[1] === 'b') { 10473 return sign * parseInt(value.slice(2), 2); 10474 } 10475 if (value[1] === 'x') { 10476 return sign * parseInt(value, 16); 10477 } 10478 return sign * parseInt(value, 8); 10479 10480 } 10481 10482 if (value.indexOf(':') !== -1) { 10483 value.split(':').forEach(function (v) { 10484 digits.unshift(parseInt(v, 10)); 10485 }); 10486 10487 value = 0; 10488 base = 1; 10489 10490 digits.forEach(function (d) { 10491 value += (d * base); 10492 base *= 60; 10493 }); 10494 10495 return sign * value; 10496 10497 } 10498 10499 return sign * parseInt(value, 10); 10500 } 10501 10502 function isInteger(object) { 10503 return ('[object Number]' === Object.prototype.toString.call(object)) && 10504 (0 === object % 1 && !common.isNegativeZero(object)); 10505 } 10506 10507 module.exports = new Type('tag:yaml.org,2002:int', { 10508 kind: 'scalar', 10509 resolve: resolveYamlInteger, 10510 construct: constructYamlInteger, 10511 predicate: isInteger, 10512 represent: { 10513 binary: function (object) { return '0b' + object.toString(2); }, 10514 octal: function (object) { return '0' + object.toString(8); }, 10515 decimal: function (object) { return object.toString(10); }, 10516 hexadecimal: function (object) { return '0x' + object.toString(16).toUpperCase(); } 10517 }, 10518 defaultStyle: 'decimal', 10519 styleAliases: { 10520 binary: [ 2, 'bin' ], 10521 octal: [ 8, 'oct' ], 10522 decimal: [ 10, 'dec' ], 10523 hexadecimal: [ 16, 'hex' ] 10524 } 10525 }); 10526 10527 },{"../common":22,"../type":33}],38:[function(require,module,exports){ 10528 'use strict'; 10529 10530 var esprima; 10531 10532 // Browserified version does not have esprima 10533 // 10534 // 1. For node.js just require module as deps 10535 // 2. For browser try to require mudule via external AMD system. 10536 // If not found - try to fallback to window.esprima. If not 10537 // found too - then fail to parse. 10538 // 10539 try { 10540 esprima = require('esprima'); 10541 } catch (_) { 10542 /*global window */ 10543 if (typeof window !== 'undefined') { esprima = window.esprima; } 10544 } 10545 10546 var Type = require('../../type'); 10547 10548 function resolveJavascriptFunction(data) { 10549 if (null === data) { 10550 return false; 10551 } 10552 10553 try { 10554 var source = '(' + data + ')', 10555 ast = esprima.parse(source, { range: true }); 10556 10557 if ('Program' !== ast.type || 10558 1 !== ast.body.length || 10559 'ExpressionStatement' !== ast.body[0].type || 10560 'FunctionExpression' !== ast.body[0].expression.type) { 10561 return false; 10562 } 10563 10564 return true; 10565 } catch (err) { 10566 return false; 10567 } 10568 } 10569 10570 function constructJavascriptFunction(data) { 10571 /*jslint evil:true*/ 10572 10573 var source = '(' + data + ')', 10574 ast = esprima.parse(source, { range: true }), 10575 params = [], 10576 body; 10577 10578 if ('Program' !== ast.type || 10579 1 !== ast.body.length || 10580 'ExpressionStatement' !== ast.body[0].type || 10581 'FunctionExpression' !== ast.body[0].expression.type) { 10582 throw new Error('Failed to resolve function'); 10583 } 10584 10585 ast.body[0].expression.params.forEach(function (param) { 10586 params.push(param.name); 10587 }); 10588 10589 body = ast.body[0].expression.body.range; 10590 10591 // Esprima's ranges include the first '{' and the last '}' characters on 10592 // function expressions. So cut them out. 10593 /*eslint-disable no-new-func*/ 10594 return new Function(params, source.slice(body[0] + 1, body[1] - 1)); 10595 } 10596 10597 function representJavascriptFunction(object /*, style*/) { 10598 return object.toString(); 10599 } 10600 10601 function isFunction(object) { 10602 return '[object Function]' === Object.prototype.toString.call(object); 10603 } 10604 10605 module.exports = new Type('tag:yaml.org,2002:js/function', { 10606 kind: 'scalar', 10607 resolve: resolveJavascriptFunction, 10608 construct: constructJavascriptFunction, 10609 predicate: isFunction, 10610 represent: representJavascriptFunction 10611 }); 10612 10613 },{"../../type":33,"esprima":50}],39:[function(require,module,exports){ 10614 'use strict'; 10615 10616 var Type = require('../../type'); 10617 10618 function resolveJavascriptRegExp(data) { 10619 if (null === data) { 10620 return false; 10621 } 10622 10623 if (0 === data.length) { 10624 return false; 10625 } 10626 10627 var regexp = data, 10628 tail = /\/([gim]*)$/.exec(data), 10629 modifiers = ''; 10630 10631 // if regexp starts with '/' it can have modifiers and must be properly closed 10632 // `/foo/gim` - modifiers tail can be maximum 3 chars 10633 if ('/' === regexp[0]) { 10634 if (tail) { 10635 modifiers = tail[1]; 10636 } 10637 10638 if (modifiers.length > 3) { return false; } 10639 // if expression starts with /, is should be properly terminated 10640 if (regexp[regexp.length - modifiers.length - 1] !== '/') { return false; } 10641 10642 regexp = regexp.slice(1, regexp.length - modifiers.length - 1); 10643 } 10644 10645 try { 10646 return true; 10647 } catch (error) { 10648 return false; 10649 } 10650 } 10651 10652 function constructJavascriptRegExp(data) { 10653 var regexp = data, 10654 tail = /\/([gim]*)$/.exec(data), 10655 modifiers = ''; 10656 10657 // `/foo/gim` - tail can be maximum 4 chars 10658 if ('/' === regexp[0]) { 10659 if (tail) { 10660 modifiers = tail[1]; 10661 } 10662 regexp = regexp.slice(1, regexp.length - modifiers.length - 1); 10663 } 10664 10665 return new RegExp(regexp, modifiers); 10666 } 10667 10668 function representJavascriptRegExp(object /*, style*/) { 10669 var result = '/' + object.source + '/'; 10670 10671 if (object.global) { 10672 result += 'g'; 10673 } 10674 10675 if (object.multiline) { 10676 result += 'm'; 10677 } 10678 10679 if (object.ignoreCase) { 10680 result += 'i'; 10681 } 10682 10683 return result; 10684 } 10685 10686 function isRegExp(object) { 10687 return '[object RegExp]' === Object.prototype.toString.call(object); 10688 } 10689 10690 module.exports = new Type('tag:yaml.org,2002:js/regexp', { 10691 kind: 'scalar', 10692 resolve: resolveJavascriptRegExp, 10693 construct: constructJavascriptRegExp, 10694 predicate: isRegExp, 10695 represent: representJavascriptRegExp 10696 }); 10697 10698 },{"../../type":33}],40:[function(require,module,exports){ 10699 'use strict'; 10700 10701 var Type = require('../../type'); 10702 10703 function resolveJavascriptUndefined() { 10704 return true; 10705 } 10706 10707 function constructJavascriptUndefined() { 10708 /*eslint-disable no-undefined*/ 10709 return undefined; 10710 } 10711 10712 function representJavascriptUndefined() { 10713 return ''; 10714 } 10715 10716 function isUndefined(object) { 10717 return 'undefined' === typeof object; 10718 } 10719 10720 module.exports = new Type('tag:yaml.org,2002:js/undefined', { 10721 kind: 'scalar', 10722 resolve: resolveJavascriptUndefined, 10723 construct: constructJavascriptUndefined, 10724 predicate: isUndefined, 10725 represent: representJavascriptUndefined 10726 }); 10727 10728 },{"../../type":33}],41:[function(require,module,exports){ 10729 'use strict'; 10730 10731 var Type = require('../type'); 10732 10733 module.exports = new Type('tag:yaml.org,2002:map', { 10734 kind: 'mapping', 10735 construct: function (data) { return null !== data ? data : {}; } 10736 }); 10737 10738 },{"../type":33}],42:[function(require,module,exports){ 10739 'use strict'; 10740 10741 var Type = require('../type'); 10742 10743 function resolveYamlMerge(data) { 10744 return '<<' === data || null === data; 10745 } 10746 10747 module.exports = new Type('tag:yaml.org,2002:merge', { 10748 kind: 'scalar', 10749 resolve: resolveYamlMerge 10750 }); 10751 10752 },{"../type":33}],43:[function(require,module,exports){ 10753 'use strict'; 10754 10755 var Type = require('../type'); 10756 10757 function resolveYamlNull(data) { 10758 if (null === data) { 10759 return true; 10760 } 10761 10762 var max = data.length; 10763 10764 return (max === 1 && data === '~') || 10765 (max === 4 && (data === 'null' || data === 'Null' || data === 'NULL')); 10766 } 10767 10768 function constructYamlNull() { 10769 return null; 10770 } 10771 10772 function isNull(object) { 10773 return null === object; 10774 } 10775 10776 module.exports = new Type('tag:yaml.org,2002:null', { 10777 kind: 'scalar', 10778 resolve: resolveYamlNull, 10779 construct: constructYamlNull, 10780 predicate: isNull, 10781 represent: { 10782 canonical: function () { return '~'; }, 10783 lowercase: function () { return 'null'; }, 10784 uppercase: function () { return 'NULL'; }, 10785 camelcase: function () { return 'Null'; } 10786 }, 10787 defaultStyle: 'lowercase' 10788 }); 10789 10790 },{"../type":33}],44:[function(require,module,exports){ 10791 'use strict'; 10792 10793 var Type = require('../type'); 10794 10795 var _hasOwnProperty = Object.prototype.hasOwnProperty; 10796 var _toString = Object.prototype.toString; 10797 10798 function resolveYamlOmap(data) { 10799 if (null === data) { 10800 return true; 10801 } 10802 10803 var objectKeys = [], index, length, pair, pairKey, pairHasKey, 10804 object = data; 10805 10806 for (index = 0, length = object.length; index < length; index += 1) { 10807 pair = object[index]; 10808 pairHasKey = false; 10809 10810 if ('[object Object]' !== _toString.call(pair)) { 10811 return false; 10812 } 10813 10814 for (pairKey in pair) { 10815 if (_hasOwnProperty.call(pair, pairKey)) { 10816 if (!pairHasKey) { 10817 pairHasKey = true; 10818 } else { 10819 return false; 10820 } 10821 } 10822 } 10823 10824 if (!pairHasKey) { 10825 return false; 10826 } 10827 10828 if (-1 === objectKeys.indexOf(pairKey)) { 10829 objectKeys.push(pairKey); 10830 } else { 10831 return false; 10832 } 10833 } 10834 10835 return true; 10836 } 10837 10838 function constructYamlOmap(data) { 10839 return null !== data ? data : []; 10840 } 10841 10842 module.exports = new Type('tag:yaml.org,2002:omap', { 10843 kind: 'sequence', 10844 resolve: resolveYamlOmap, 10845 construct: constructYamlOmap 10846 }); 10847 10848 },{"../type":33}],45:[function(require,module,exports){ 10849 'use strict'; 10850 10851 var Type = require('../type'); 10852 10853 var _toString = Object.prototype.toString; 10854 10855 function resolveYamlPairs(data) { 10856 if (null === data) { 10857 return true; 10858 } 10859 10860 var index, length, pair, keys, result, 10861 object = data; 10862 10863 result = new Array(object.length); 10864 10865 for (index = 0, length = object.length; index < length; index += 1) { 10866 pair = object[index]; 10867 10868 if ('[object Object]' !== _toString.call(pair)) { 10869 return false; 10870 } 10871 10872 keys = Object.keys(pair); 10873 10874 if (1 !== keys.length) { 10875 return false; 10876 } 10877 10878 result[index] = [ keys[0], pair[keys[0]] ]; 10879 } 10880 10881 return true; 10882 } 10883 10884 function constructYamlPairs(data) { 10885 if (null === data) { 10886 return []; 10887 } 10888 10889 var index, length, pair, keys, result, 10890 object = data; 10891 10892 result = new Array(object.length); 10893 10894 for (index = 0, length = object.length; index < length; index += 1) { 10895 pair = object[index]; 10896 10897 keys = Object.keys(pair); 10898 10899 result[index] = [ keys[0], pair[keys[0]] ]; 10900 } 10901 10902 return result; 10903 } 10904 10905 module.exports = new Type('tag:yaml.org,2002:pairs', { 10906 kind: 'sequence', 10907 resolve: resolveYamlPairs, 10908 construct: constructYamlPairs 10909 }); 10910 10911 },{"../type":33}],46:[function(require,module,exports){ 10912 'use strict'; 10913 10914 var Type = require('../type'); 10915 10916 module.exports = new Type('tag:yaml.org,2002:seq', { 10917 kind: 'sequence', 10918 construct: function (data) { return null !== data ? data : []; } 10919 }); 10920 10921 },{"../type":33}],47:[function(require,module,exports){ 10922 'use strict'; 10923 10924 var Type = require('../type'); 10925 10926 var _hasOwnProperty = Object.prototype.hasOwnProperty; 10927 10928 function resolveYamlSet(data) { 10929 if (null === data) { 10930 return true; 10931 } 10932 10933 var key, object = data; 10934 10935 for (key in object) { 10936 if (_hasOwnProperty.call(object, key)) { 10937 if (null !== object[key]) { 10938 return false; 10939 } 10940 } 10941 } 10942 10943 return true; 10944 } 10945 10946 function constructYamlSet(data) { 10947 return null !== data ? data : {}; 10948 } 10949 10950 module.exports = new Type('tag:yaml.org,2002:set', { 10951 kind: 'mapping', 10952 resolve: resolveYamlSet, 10953 construct: constructYamlSet 10954 }); 10955 10956 },{"../type":33}],48:[function(require,module,exports){ 10957 'use strict'; 10958 10959 var Type = require('../type'); 10960 10961 module.exports = new Type('tag:yaml.org,2002:str', { 10962 kind: 'scalar', 10963 construct: function (data) { return null !== data ? data : ''; } 10964 }); 10965 10966 },{"../type":33}],49:[function(require,module,exports){ 10967 'use strict'; 10968 10969 var Type = require('../type'); 10970 10971 var YAML_TIMESTAMP_REGEXP = new RegExp( 10972 '^([0-9][0-9][0-9][0-9])' + // [1] year 10973 '-([0-9][0-9]?)' + // [2] month 10974 '-([0-9][0-9]?)' + // [3] day 10975 '(?:(?:[Tt]|[ \\t]+)' + // ... 10976 '([0-9][0-9]?)' + // [4] hour 10977 ':([0-9][0-9])' + // [5] minute 10978 ':([0-9][0-9])' + // [6] second 10979 '(?:\\.([0-9]*))?' + // [7] fraction 10980 '(?:[ \\t]*(Z|([-+])([0-9][0-9]?)' + // [8] tz [9] tz_sign [10] tz_hour 10981 '(?::([0-9][0-9]))?))?)?$'); // [11] tz_minute 10982 10983 function resolveYamlTimestamp(data) { 10984 if (null === data) { 10985 return false; 10986 } 10987 10988 if (YAML_TIMESTAMP_REGEXP.exec(data) === null) { 10989 return false; 10990 } 10991 10992 return true; 10993 } 10994 10995 function constructYamlTimestamp(data) { 10996 var match, year, month, day, hour, minute, second, fraction = 0, 10997 delta = null, tz_hour, tz_minute, date; 10998 10999 match = YAML_TIMESTAMP_REGEXP.exec(data); 11000 11001 if (null === match) { 11002 throw new Error('Date resolve error'); 11003 } 11004 11005 // match: [1] year [2] month [3] day 11006 11007 year = +(match[1]); 11008 month = +(match[2]) - 1; // JS month starts with 0 11009 day = +(match[3]); 11010 11011 if (!match[4]) { // no hour 11012 return new Date(Date.UTC(year, month, day)); 11013 } 11014 11015 // match: [4] hour [5] minute [6] second [7] fraction 11016 11017 hour = +(match[4]); 11018 minute = +(match[5]); 11019 second = +(match[6]); 11020 11021 if (match[7]) { 11022 fraction = match[7].slice(0, 3); 11023 while (fraction.length < 3) { // milli-seconds 11024 fraction += '0'; 11025 } 11026 fraction = +fraction; 11027 } 11028 11029 // match: [8] tz [9] tz_sign [10] tz_hour [11] tz_minute 11030 11031 if (match[9]) { 11032 tz_hour = +(match[10]); 11033 tz_minute = +(match[11] || 0); 11034 delta = (tz_hour * 60 + tz_minute) * 60000; // delta in mili-seconds 11035 if ('-' === match[9]) { 11036 delta = -delta; 11037 } 11038 } 11039 11040 date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction)); 11041 11042 if (delta) { 11043 date.setTime(date.getTime() - delta); 11044 } 11045 11046 return date; 11047 } 11048 11049 function representYamlTimestamp(object /*, style*/) { 11050 return object.toISOString(); 11051 } 11052 11053 module.exports = new Type('tag:yaml.org,2002:timestamp', { 11054 kind: 'scalar', 11055 resolve: resolveYamlTimestamp, 11056 construct: constructYamlTimestamp, 11057 instanceOf: Date, 11058 represent: representYamlTimestamp 11059 }); 11060 11061 },{"../type":33}],50:[function(require,module,exports){ 11062 /* 11063 Copyright (c) jQuery Foundation, Inc. and Contributors, All Rights Reserved. 11064 11065 Redistribution and use in source and binary forms, with or without 11066 modification, are permitted provided that the following conditions are met: 11067 11068 * Redistributions of source code must retain the above copyright 11069 notice, this list of conditions and the following disclaimer. 11070 * Redistributions in binary form must reproduce the above copyright 11071 notice, this list of conditions and the following disclaimer in the 11072 documentation and/or other materials provided with the distribution. 11073 11074 THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 11075 AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 11076 IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 11077 ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY 11078 DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 11079 (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 11080 LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND 11081 ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 11082 (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF 11083 THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 11084 */ 11085 11086 (function (root, factory) { 11087 'use strict'; 11088 11089 // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js, 11090 // Rhino, and plain browser loading. 11091 11092 /* istanbul ignore next */ 11093 if (typeof define === 'function' && define.amd) { 11094 define(['exports'], factory); 11095 } else if (typeof exports !== 'undefined') { 11096 factory(exports); 11097 } else { 11098 factory((root.esprima = {})); 11099 } 11100 }(this, function (exports) { 11101 'use strict'; 11102 11103 var Token, 11104 TokenName, 11105 FnExprTokens, 11106 Syntax, 11107 PlaceHolders, 11108 Messages, 11109 Regex, 11110 source, 11111 strict, 11112 index, 11113 lineNumber, 11114 lineStart, 11115 hasLineTerminator, 11116 lastIndex, 11117 lastLineNumber, 11118 lastLineStart, 11119 startIndex, 11120 startLineNumber, 11121 startLineStart, 11122 scanning, 11123 length, 11124 lookahead, 11125 state, 11126 extra, 11127 isBindingElement, 11128 isAssignmentTarget, 11129 firstCoverInitializedNameError; 11130 11131 Token = { 11132 BooleanLiteral: 1, 11133 EOF: 2, 11134 Identifier: 3, 11135 Keyword: 4, 11136 NullLiteral: 5, 11137 NumericLiteral: 6, 11138 Punctuator: 7, 11139 StringLiteral: 8, 11140 RegularExpression: 9, 11141 Template: 10 11142 }; 11143 11144 TokenName = {}; 11145 TokenName[Token.BooleanLiteral] = 'Boolean'; 11146 TokenName[Token.EOF] = '<end>'; 11147 TokenName[Token.Identifier] = 'Identifier'; 11148 TokenName[Token.Keyword] = 'Keyword'; 11149 TokenName[Token.NullLiteral] = 'Null'; 11150 TokenName[Token.NumericLiteral] = 'Numeric'; 11151 TokenName[Token.Punctuator] = 'Punctuator'; 11152 TokenName[Token.StringLiteral] = 'String'; 11153 TokenName[Token.RegularExpression] = 'RegularExpression'; 11154 TokenName[Token.Template] = 'Template'; 11155 11156 // A function following one of those tokens is an expression. 11157 FnExprTokens = ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new', 11158 'return', 'case', 'delete', 'throw', 'void', 11159 // assignment operators 11160 '=', '+=', '-=', '*=', '/=', '%=', '<<=', '>>=', '>>>=', 11161 '&=', '|=', '^=', ',', 11162 // binary/unary operators 11163 '+', '-', '*', '/', '%', '++', '--', '<<', '>>', '>>>', '&', 11164 '|', '^', '!', '~', '&&', '||', '?', ':', '===', '==', '>=', 11165 '<=', '<', '>', '!=', '!==']; 11166 11167 Syntax = { 11168 AssignmentExpression: 'AssignmentExpression', 11169 AssignmentPattern: 'AssignmentPattern', 11170 ArrayExpression: 'ArrayExpression', 11171 ArrayPattern: 'ArrayPattern', 11172 ArrowFunctionExpression: 'ArrowFunctionExpression', 11173 BlockStatement: 'BlockStatement', 11174 BinaryExpression: 'BinaryExpression', 11175 BreakStatement: 'BreakStatement', 11176 CallExpression: 'CallExpression', 11177 CatchClause: 'CatchClause', 11178 ClassBody: 'ClassBody', 11179 ClassDeclaration: 'ClassDeclaration', 11180 ClassExpression: 'ClassExpression', 11181 ConditionalExpression: 'ConditionalExpression', 11182 ContinueStatement: 'ContinueStatement', 11183 DoWhileStatement: 'DoWhileStatement', 11184 DebuggerStatement: 'DebuggerStatement', 11185 EmptyStatement: 'EmptyStatement', 11186 ExportAllDeclaration: 'ExportAllDeclaration', 11187 ExportDefaultDeclaration: 'ExportDefaultDeclaration', 11188 ExportNamedDeclaration: 'ExportNamedDeclaration', 11189 ExportSpecifier: 'ExportSpecifier', 11190 ExpressionStatement: 'ExpressionStatement', 11191 ForStatement: 'ForStatement', 11192 ForOfStatement: 'ForOfStatement', 11193 ForInStatement: 'ForInStatement', 11194 FunctionDeclaration: 'FunctionDeclaration', 11195 FunctionExpression: 'FunctionExpression', 11196 Identifier: 'Identifier', 11197 IfStatement: 'IfStatement', 11198 ImportDeclaration: 'ImportDeclaration', 11199 ImportDefaultSpecifier: 'ImportDefaultSpecifier', 11200 ImportNamespaceSpecifier: 'ImportNamespaceSpecifier', 11201 ImportSpecifier: 'ImportSpecifier', 11202 Literal: 'Literal', 11203 LabeledStatement: 'LabeledStatement', 11204 LogicalExpression: 'LogicalExpression', 11205 MemberExpression: 'MemberExpression', 11206 MetaProperty: 'MetaProperty', 11207 MethodDefinition: 'MethodDefinition', 11208 NewExpression: 'NewExpression', 11209 ObjectExpression: 'ObjectExpression', 11210 ObjectPattern: 'ObjectPattern', 11211 Program: 'Program', 11212 Property: 'Property', 11213 RestElement: 'RestElement', 11214 ReturnStatement: 'ReturnStatement', 11215 SequenceExpression: 'SequenceExpression', 11216 SpreadElement: 'SpreadElement', 11217 Super: 'Super', 11218 SwitchCase: 'SwitchCase', 11219 SwitchStatement: 'SwitchStatement', 11220 TaggedTemplateExpression: 'TaggedTemplateExpression', 11221 TemplateElement: 'TemplateElement', 11222 TemplateLiteral: 'TemplateLiteral', 11223 ThisExpression: 'ThisExpression', 11224 ThrowStatement: 'ThrowStatement', 11225 TryStatement: 'TryStatement', 11226 UnaryExpression: 'UnaryExpression', 11227 UpdateExpression: 'UpdateExpression', 11228 VariableDeclaration: 'VariableDeclaration', 11229 VariableDeclarator: 'VariableDeclarator', 11230 WhileStatement: 'WhileStatement', 11231 WithStatement: 'WithStatement', 11232 YieldExpression: 'YieldExpression' 11233 }; 11234 11235 PlaceHolders = { 11236 ArrowParameterPlaceHolder: 'ArrowParameterPlaceHolder' 11237 }; 11238 11239 // Error messages should be identical to V8. 11240 Messages = { 11241 UnexpectedToken: 'Unexpected token %0', 11242 UnexpectedNumber: 'Unexpected number', 11243 UnexpectedString: 'Unexpected string', 11244 UnexpectedIdentifier: 'Unexpected identifier', 11245 UnexpectedReserved: 'Unexpected reserved word', 11246 UnexpectedTemplate: 'Unexpected quasi %0', 11247 UnexpectedEOS: 'Unexpected end of input', 11248 NewlineAfterThrow: 'Illegal newline after throw', 11249 InvalidRegExp: 'Invalid regular expression', 11250 UnterminatedRegExp: 'Invalid regular expression: missing /', 11251 InvalidLHSInAssignment: 'Invalid left-hand side in assignment', 11252 InvalidLHSInForIn: 'Invalid left-hand side in for-in', 11253 InvalidLHSInForLoop: 'Invalid left-hand side in for-loop', 11254 MultipleDefaultsInSwitch: 'More than one default clause in switch statement', 11255 NoCatchOrFinally: 'Missing catch or finally after try', 11256 UnknownLabel: 'Undefined label \'%0\'', 11257 Redeclaration: '%0 \'%1\' has already been declared', 11258 IllegalContinue: 'Illegal continue statement', 11259 IllegalBreak: 'Illegal break statement', 11260 IllegalReturn: 'Illegal return statement', 11261 StrictModeWith: 'Strict mode code may not include a with statement', 11262 StrictCatchVariable: 'Catch variable may not be eval or arguments in strict mode', 11263 StrictVarName: 'Variable name may not be eval or arguments in strict mode', 11264 StrictParamName: 'Parameter name eval or arguments is not allowed in strict mode', 11265 StrictParamDupe: 'Strict mode function may not have duplicate parameter names', 11266 StrictFunctionName: 'Function name may not be eval or arguments in strict mode', 11267 StrictOctalLiteral: 'Octal literals are not allowed in strict mode.', 11268 StrictDelete: 'Delete of an unqualified identifier in strict mode.', 11269 StrictLHSAssignment: 'Assignment to eval or arguments is not allowed in strict mode', 11270 StrictLHSPostfix: 'Postfix increment/decrement may not have eval or arguments operand in strict mode', 11271 StrictLHSPrefix: 'Prefix increment/decrement may not have eval or arguments operand in strict mode', 11272 StrictReservedWord: 'Use of future reserved word in strict mode', 11273 TemplateOctalLiteral: 'Octal literals are not allowed in template strings.', 11274 ParameterAfterRestParameter: 'Rest parameter must be last formal parameter', 11275 DefaultRestParameter: 'Unexpected token =', 11276 ObjectPatternAsRestParameter: 'Unexpected token {', 11277 DuplicateProtoProperty: 'Duplicate __proto__ fields are not allowed in object literals', 11278 ConstructorSpecialMethod: 'Class constructor may not be an accessor', 11279 DuplicateConstructor: 'A class may only have one constructor', 11280 StaticPrototype: 'Classes may not have static property named prototype', 11281 MissingFromClause: 'Unexpected token', 11282 NoAsAfterImportNamespace: 'Unexpected token', 11283 InvalidModuleSpecifier: 'Unexpected token', 11284 IllegalImportDeclaration: 'Unexpected token', 11285 IllegalExportDeclaration: 'Unexpected token', 11286 DuplicateBinding: 'Duplicate binding %0' 11287 }; 11288 11289 // See also tools/generate-unicode-regex.js. 11290 Regex = { 11291 // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierStart: 11292 NonAsciiIdentifierStart: /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0-\u08B2\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309B-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDE00-\uDE11\uDE13-\uDE2B\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF5D-\uDF61]|\uD805[\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDE00-\uDE2F\uDE44\uDE80-\uDEAA]|\uD806[\uDCA0-\uDCDF\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]/, 11293 11294 // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierPart: 11295 NonAsciiIdentifierPart: /[\xAA\xB5\xB7\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u08A0-\u08B2\u08E4-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58\u0C59\u0C60-\u0C63\u0C66-\u0C6F\u0C81-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D01-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D57\u0D60-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1369-\u1371\u1380-\u138F\u13A0-\u13F4\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1CD0-\u1CD2\u1CD4-\u1CF6\u1CF8\u1CF9\u1D00-\u1DF5\u1DFC-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u200C\u200D\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2118-\u211D\u2124\u2126\u2128\u212A-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA69D\uA69F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA78E\uA790-\uA7AD\uA7B0\uA7B1\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C4\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB5F\uAB64\uAB65\uABC0-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2D\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF30-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDD0-\uDDDA\uDE00-\uDE11\uDE13-\uDE37\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF01-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9]|\uD806[\uDCA0-\uDCE9\uDCFF\uDEC0-\uDEF8]|\uD808[\uDC00-\uDF98]|\uD809[\uDC00-\uDC6E]|[\uD80C\uD840-\uD868\uD86A-\uD86C][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F]|\uD82C[\uDC00\uDC01]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/ 11296 }; 11297 11298 // Ensure the condition is true, otherwise throw an error. 11299 // This is only to have a better contract semantic, i.e. another safety net 11300 // to catch a logic error. The condition shall be fulfilled in normal case. 11301 // Do NOT use this to enforce a certain condition on any user input. 11302 11303 function assert(condition, message) { 11304 /* istanbul ignore if */ 11305 if (!condition) { 11306 throw new Error('ASSERT: ' + message); 11307 } 11308 } 11309 11310 function isDecimalDigit(ch) { 11311 return (ch >= 0x30 && ch <= 0x39); // 0..9 11312 } 11313 11314 function isHexDigit(ch) { 11315 return '0123456789abcdefABCDEF'.indexOf(ch) >= 0; 11316 } 11317 11318 function isOctalDigit(ch) { 11319 return '01234567'.indexOf(ch) >= 0; 11320 } 11321 11322 function octalToDecimal(ch) { 11323 // \0 is not octal escape sequence 11324 var octal = (ch !== '0'), code = '01234567'.indexOf(ch); 11325 11326 if (index < length && isOctalDigit(source[index])) { 11327 octal = true; 11328 code = code * 8 + '01234567'.indexOf(source[index++]); 11329 11330 // 3 digits are only allowed when string starts 11331 // with 0, 1, 2, 3 11332 if ('0123'.indexOf(ch) >= 0 && 11333 index < length && 11334 isOctalDigit(source[index])) { 11335 code = code * 8 + '01234567'.indexOf(source[index++]); 11336 } 11337 } 11338 11339 return { 11340 code: code, 11341 octal: octal 11342 }; 11343 } 11344 11345 // ECMA-262 11.2 White Space 11346 11347 function isWhiteSpace(ch) { 11348 return (ch === 0x20) || (ch === 0x09) || (ch === 0x0B) || (ch === 0x0C) || (ch === 0xA0) || 11349 (ch >= 0x1680 && [0x1680, 0x180E, 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, 0x202F, 0x205F, 0x3000, 0xFEFF].indexOf(ch) >= 0); 11350 } 11351 11352 // ECMA-262 11.3 Line Terminators 11353 11354 function isLineTerminator(ch) { 11355 return (ch === 0x0A) || (ch === 0x0D) || (ch === 0x2028) || (ch === 0x2029); 11356 } 11357 11358 // ECMA-262 11.6 Identifier Names and Identifiers 11359 11360 function fromCodePoint(cp) { 11361 return (cp < 0x10000) ? String.fromCharCode(cp) : 11362 String.fromCharCode(0xD800 + ((cp - 0x10000) >> 10)) + 11363 String.fromCharCode(0xDC00 + ((cp - 0x10000) & 1023)); 11364 } 11365 11366 function isIdentifierStart(ch) { 11367 return (ch === 0x24) || (ch === 0x5F) || // $ (dollar) and _ (underscore) 11368 (ch >= 0x41 && ch <= 0x5A) || // A..Z 11369 (ch >= 0x61 && ch <= 0x7A) || // a..z 11370 (ch === 0x5C) || // \ (backslash) 11371 ((ch >= 0x80) && Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch))); 11372 } 11373 11374 function isIdentifierPart(ch) { 11375 return (ch === 0x24) || (ch === 0x5F) || // $ (dollar) and _ (underscore) 11376 (ch >= 0x41 && ch <= 0x5A) || // A..Z 11377 (ch >= 0x61 && ch <= 0x7A) || // a..z 11378 (ch >= 0x30 && ch <= 0x39) || // 0..9 11379 (ch === 0x5C) || // \ (backslash) 11380 ((ch >= 0x80) && Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch))); 11381 } 11382 11383 // ECMA-262 11.6.2.2 Future Reserved Words 11384 11385 function isFutureReservedWord(id) { 11386 switch (id) { 11387 case 'enum': 11388 case 'export': 11389 case 'import': 11390 case 'super': 11391 return true; 11392 default: 11393 return false; 11394 } 11395 } 11396 11397 function isStrictModeReservedWord(id) { 11398 switch (id) { 11399 case 'implements': 11400 case 'interface': 11401 case 'package': 11402 case 'private': 11403 case 'protected': 11404 case 'public': 11405 case 'static': 11406 case 'yield': 11407 case 'let': 11408 return true; 11409 default: 11410 return false; 11411 } 11412 } 11413 11414 function isRestrictedWord(id) { 11415 return id === 'eval' || id === 'arguments'; 11416 } 11417 11418 // ECMA-262 11.6.2.1 Keywords 11419 11420 function isKeyword(id) { 11421 switch (id.length) { 11422 case 2: 11423 return (id === 'if') || (id === 'in') || (id === 'do'); 11424 case 3: 11425 return (id === 'var') || (id === 'for') || (id === 'new') || 11426 (id === 'try') || (id === 'let'); 11427 case 4: 11428 return (id === 'this') || (id === 'else') || (id === 'case') || 11429 (id === 'void') || (id === 'with') || (id === 'enum'); 11430 case 5: 11431 return (id === 'while') || (id === 'break') || (id === 'catch') || 11432 (id === 'throw') || (id === 'const') || (id === 'yield') || 11433 (id === 'class') || (id === 'super'); 11434 case 6: 11435 return (id === 'return') || (id === 'typeof') || (id === 'delete') || 11436 (id === 'switch') || (id === 'export') || (id === 'import'); 11437 case 7: 11438 return (id === 'default') || (id === 'finally') || (id === 'extends'); 11439 case 8: 11440 return (id === 'function') || (id === 'continue') || (id === 'debugger'); 11441 case 10: 11442 return (id === 'instanceof'); 11443 default: 11444 return false; 11445 } 11446 } 11447 11448 // ECMA-262 11.4 Comments 11449 11450 function addComment(type, value, start, end, loc) { 11451 var comment; 11452 11453 assert(typeof start === 'number', 'Comment must have valid position'); 11454 11455 state.lastCommentStart = start; 11456 11457 comment = { 11458 type: type, 11459 value: value 11460 }; 11461 if (extra.range) { 11462 comment.range = [start, end]; 11463 } 11464 if (extra.loc) { 11465 comment.loc = loc; 11466 } 11467 extra.comments.push(comment); 11468 if (extra.attachComment) { 11469 extra.leadingComments.push(comment); 11470 extra.trailingComments.push(comment); 11471 } 11472 if (extra.tokenize) { 11473 comment.type = comment.type + 'Comment'; 11474 if (extra.delegate) { 11475 comment = extra.delegate(comment); 11476 } 11477 extra.tokens.push(comment); 11478 } 11479 } 11480 11481 function skipSingleLineComment(offset) { 11482 var start, loc, ch, comment; 11483 11484 start = index - offset; 11485 loc = { 11486 start: { 11487 line: lineNumber, 11488 column: index - lineStart - offset 11489 } 11490 }; 11491 11492 while (index < length) { 11493 ch = source.charCodeAt(index); 11494 ++index; 11495 if (isLineTerminator(ch)) { 11496 hasLineTerminator = true; 11497 if (extra.comments) { 11498 comment = source.slice(start + offset, index - 1); 11499 loc.end = { 11500 line: lineNumber, 11501 column: index - lineStart - 1 11502 }; 11503 addComment('Line', comment, start, index - 1, loc); 11504 } 11505 if (ch === 13 && source.charCodeAt(index) === 10) { 11506 ++index; 11507 } 11508 ++lineNumber; 11509 lineStart = index; 11510 return; 11511 } 11512 } 11513 11514 if (extra.comments) { 11515 comment = source.slice(start + offset, index); 11516 loc.end = { 11517 line: lineNumber, 11518 column: index - lineStart 11519 }; 11520 addComment('Line', comment, start, index, loc); 11521 } 11522 } 11523 11524 function skipMultiLineComment() { 11525 var start, loc, ch, comment; 11526 11527 if (extra.comments) { 11528 start = index - 2; 11529 loc = { 11530 start: { 11531 line: lineNumber, 11532 column: index - lineStart - 2 11533 } 11534 }; 11535 } 11536 11537 while (index < length) { 11538 ch = source.charCodeAt(index); 11539 if (isLineTerminator(ch)) { 11540 if (ch === 0x0D && source.charCodeAt(index + 1) === 0x0A) { 11541 ++index; 11542 } 11543 hasLineTerminator = true; 11544 ++lineNumber; 11545 ++index; 11546 lineStart = index; 11547 } else if (ch === 0x2A) { 11548 // Block comment ends with '*/'. 11549 if (source.charCodeAt(index + 1) === 0x2F) { 11550 ++index; 11551 ++index; 11552 if (extra.comments) { 11553 comment = source.slice(start + 2, index - 2); 11554 loc.end = { 11555 line: lineNumber, 11556 column: index - lineStart 11557 }; 11558 addComment('Block', comment, start, index, loc); 11559 } 11560 return; 11561 } 11562 ++index; 11563 } else { 11564 ++index; 11565 } 11566 } 11567 11568 // Ran off the end of the file - the whole thing is a comment 11569 if (extra.comments) { 11570 loc.end = { 11571 line: lineNumber, 11572 column: index - lineStart 11573 }; 11574 comment = source.slice(start + 2, index); 11575 addComment('Block', comment, start, index, loc); 11576 } 11577 tolerateUnexpectedToken(); 11578 } 11579 11580 function skipComment() { 11581 var ch, start; 11582 hasLineTerminator = false; 11583 11584 start = (index === 0); 11585 while (index < length) { 11586 ch = source.charCodeAt(index); 11587 11588 if (isWhiteSpace(ch)) { 11589 ++index; 11590 } else if (isLineTerminator(ch)) { 11591 hasLineTerminator = true; 11592 ++index; 11593 if (ch === 0x0D && source.charCodeAt(index) === 0x0A) { 11594 ++index; 11595 } 11596 ++lineNumber; 11597 lineStart = index; 11598 start = true; 11599 } else if (ch === 0x2F) { // U+002F is '/' 11600 ch = source.charCodeAt(index + 1); 11601 if (ch === 0x2F) { 11602 ++index; 11603 ++index; 11604 skipSingleLineComment(2); 11605 start = true; 11606 } else if (ch === 0x2A) { // U+002A is '*' 11607 ++index; 11608 ++index; 11609 skipMultiLineComment(); 11610 } else { 11611 break; 11612 } 11613 } else if (start && ch === 0x2D) { // U+002D is '-' 11614 // U+003E is '>' 11615 if ((source.charCodeAt(index + 1) === 0x2D) && (source.charCodeAt(index + 2) === 0x3E)) { 11616 // '-->' is a single-line comment 11617 index += 3; 11618 skipSingleLineComment(3); 11619 } else { 11620 break; 11621 } 11622 } else if (ch === 0x3C) { // U+003C is '<' 11623 if (source.slice(index + 1, index + 4) === '!--') { 11624 ++index; // `<` 11625 ++index; // `!` 11626 ++index; // `-` 11627 ++index; // `-` 11628 skipSingleLineComment(4); 11629 } else { 11630 break; 11631 } 11632 } else { 11633 break; 11634 } 11635 } 11636 } 11637 11638 function scanHexEscape(prefix) { 11639 var i, len, ch, code = 0; 11640 11641 len = (prefix === 'u') ? 4 : 2; 11642 for (i = 0; i < len; ++i) { 11643 if (index < length && isHexDigit(source[index])) { 11644 ch = source[index++]; 11645 code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase()); 11646 } else { 11647 return ''; 11648 } 11649 } 11650 return String.fromCharCode(code); 11651 } 11652 11653 function scanUnicodeCodePointEscape() { 11654 var ch, code; 11655 11656 ch = source[index]; 11657 code = 0; 11658 11659 // At least, one hex digit is required. 11660 if (ch === '}') { 11661 throwUnexpectedToken(); 11662 } 11663 11664 while (index < length) { 11665 ch = source[index++]; 11666 if (!isHexDigit(ch)) { 11667 break; 11668 } 11669 code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase()); 11670 } 11671 11672 if (code > 0x10FFFF || ch !== '}') { 11673 throwUnexpectedToken(); 11674 } 11675 11676 return fromCodePoint(code); 11677 } 11678 11679 function codePointAt(i) { 11680 var cp, first, second; 11681 11682 cp = source.charCodeAt(i); 11683 if (cp >= 0xD800 && cp <= 0xDBFF) { 11684 second = source.charCodeAt(i + 1); 11685 if (second >= 0xDC00 && second <= 0xDFFF) { 11686 first = cp; 11687 cp = (first - 0xD800) * 0x400 + second - 0xDC00 + 0x10000; 11688 } 11689 } 11690 11691 return cp; 11692 } 11693 11694 function getComplexIdentifier() { 11695 var cp, ch, id; 11696 11697 cp = codePointAt(index); 11698 id = fromCodePoint(cp); 11699 index += id.length; 11700 11701 // '\u' (U+005C, U+0075) denotes an escaped character. 11702 if (cp === 0x5C) { 11703 if (source.charCodeAt(index) !== 0x75) { 11704 throwUnexpectedToken(); 11705 } 11706 ++index; 11707 if (source[index] === '{') { 11708 ++index; 11709 ch = scanUnicodeCodePointEscape(); 11710 } else { 11711 ch = scanHexEscape('u'); 11712 cp = ch.charCodeAt(0); 11713 if (!ch || ch === '\\' || !isIdentifierStart(cp)) { 11714 throwUnexpectedToken(); 11715 } 11716 } 11717 id = ch; 11718 } 11719 11720 while (index < length) { 11721 cp = codePointAt(index); 11722 if (!isIdentifierPart(cp)) { 11723 break; 11724 } 11725 ch = fromCodePoint(cp); 11726 id += ch; 11727 index += ch.length; 11728 11729 // '\u' (U+005C, U+0075) denotes an escaped character. 11730 if (cp === 0x5C) { 11731 id = id.substr(0, id.length - 1); 11732 if (source.charCodeAt(index) !== 0x75) { 11733 throwUnexpectedToken(); 11734 } 11735 ++index; 11736 if (source[index] === '{') { 11737 ++index; 11738 ch = scanUnicodeCodePointEscape(); 11739 } else { 11740 ch = scanHexEscape('u'); 11741 cp = ch.charCodeAt(0); 11742 if (!ch || ch === '\\' || !isIdentifierPart(cp)) { 11743 throwUnexpectedToken(); 11744 } 11745 } 11746 id += ch; 11747 } 11748 } 11749 11750 return id; 11751 } 11752 11753 function getIdentifier() { 11754 var start, ch; 11755 11756 start = index++; 11757 while (index < length) { 11758 ch = source.charCodeAt(index); 11759 if (ch === 0x5C) { 11760 // Blackslash (U+005C) marks Unicode escape sequence. 11761 index = start; 11762 return getComplexIdentifier(); 11763 } else if (ch >= 0xD800 && ch < 0xDFFF) { 11764 // Need to handle surrogate pairs. 11765 index = start; 11766 return getComplexIdentifier(); 11767 } 11768 if (isIdentifierPart(ch)) { 11769 ++index; 11770 } else { 11771 break; 11772 } 11773 } 11774 11775 return source.slice(start, index); 11776 } 11777 11778 function scanIdentifier() { 11779 var start, id, type; 11780 11781 start = index; 11782 11783 // Backslash (U+005C) starts an escaped character. 11784 id = (source.charCodeAt(index) === 0x5C) ? getComplexIdentifier() : getIdentifier(); 11785 11786 // There is no keyword or literal with only one character. 11787 // Thus, it must be an identifier. 11788 if (id.length === 1) { 11789 type = Token.Identifier; 11790 } else if (isKeyword(id)) { 11791 type = Token.Keyword; 11792 } else if (id === 'null') { 11793 type = Token.NullLiteral; 11794 } else if (id === 'true' || id === 'false') { 11795 type = Token.BooleanLiteral; 11796 } else { 11797 type = Token.Identifier; 11798 } 11799 11800 return { 11801 type: type, 11802 value: id, 11803 lineNumber: lineNumber, 11804 lineStart: lineStart, 11805 start: start, 11806 end: index 11807 }; 11808 } 11809 11810 11811 // ECMA-262 11.7 Punctuators 11812 11813 function scanPunctuator() { 11814 var token, str; 11815 11816 token = { 11817 type: Token.Punctuator, 11818 value: '', 11819 lineNumber: lineNumber, 11820 lineStart: lineStart, 11821 start: index, 11822 end: index 11823 }; 11824 11825 // Check for most common single-character punctuators. 11826 str = source[index]; 11827 switch (str) { 11828 11829 case '(': 11830 if (extra.tokenize) { 11831 extra.openParenToken = extra.tokenValues.length; 11832 } 11833 ++index; 11834 break; 11835 11836 case '{': 11837 if (extra.tokenize) { 11838 extra.openCurlyToken = extra.tokenValues.length; 11839 } 11840 state.curlyStack.push('{'); 11841 ++index; 11842 break; 11843 11844 case '.': 11845 ++index; 11846 if (source[index] === '.' && source[index + 1] === '.') { 11847 // Spread operator: ... 11848 index += 2; 11849 str = '...'; 11850 } 11851 break; 11852 11853 case '}': 11854 ++index; 11855 state.curlyStack.pop(); 11856 break; 11857 case ')': 11858 case ';': 11859 case ',': 11860 case '[': 11861 case ']': 11862 case ':': 11863 case '?': 11864 case '~': 11865 ++index; 11866 break; 11867 11868 default: 11869 // 4-character punctuator. 11870 str = source.substr(index, 4); 11871 if (str === '>>>=') { 11872 index += 4; 11873 } else { 11874 11875 // 3-character punctuators. 11876 str = str.substr(0, 3); 11877 if (str === '===' || str === '!==' || str === '>>>' || 11878 str === '<<=' || str === '>>=') { 11879 index += 3; 11880 } else { 11881 11882 // 2-character punctuators. 11883 str = str.substr(0, 2); 11884 if (str === '&&' || str === '||' || str === '==' || str === '!=' || 11885 str === '+=' || str === '-=' || str === '*=' || str === '/=' || 11886 str === '++' || str === '--' || str === '<<' || str === '>>' || 11887 str === '&=' || str === '|=' || str === '^=' || str === '%=' || 11888 str === '<=' || str === '>=' || str === '=>') { 11889 index += 2; 11890 } else { 11891 11892 // 1-character punctuators. 11893 str = source[index]; 11894 if ('<>=!+-*%&|^/'.indexOf(str) >= 0) { 11895 ++index; 11896 } 11897 } 11898 } 11899 } 11900 } 11901 11902 if (index === token.start) { 11903 throwUnexpectedToken(); 11904 } 11905 11906 token.end = index; 11907 token.value = str; 11908 return token; 11909 } 11910 11911 // ECMA-262 11.8.3 Numeric Literals 11912 11913 function scanHexLiteral(start) { 11914 var number = ''; 11915 11916 while (index < length) { 11917 if (!isHexDigit(source[index])) { 11918 break; 11919 } 11920 number += source[index++]; 11921 } 11922 11923 if (number.length === 0) { 11924 throwUnexpectedToken(); 11925 } 11926 11927 if (isIdentifierStart(source.charCodeAt(index))) { 11928 throwUnexpectedToken(); 11929 } 11930 11931 return { 11932 type: Token.NumericLiteral, 11933 value: parseInt('0x' + number, 16), 11934 lineNumber: lineNumber, 11935 lineStart: lineStart, 11936 start: start, 11937 end: index 11938 }; 11939 } 11940 11941 function scanBinaryLiteral(start) { 11942 var ch, number; 11943 11944 number = ''; 11945 11946 while (index < length) { 11947 ch = source[index]; 11948 if (ch !== '0' && ch !== '1') { 11949 break; 11950 } 11951 number += source[index++]; 11952 } 11953 11954 if (number.length === 0) { 11955 // only 0b or 0B 11956 throwUnexpectedToken(); 11957 } 11958 11959 if (index < length) { 11960 ch = source.charCodeAt(index); 11961 /* istanbul ignore else */ 11962 if (isIdentifierStart(ch) || isDecimalDigit(ch)) { 11963 throwUnexpectedToken(); 11964 } 11965 } 11966 11967 return { 11968 type: Token.NumericLiteral, 11969 value: parseInt(number, 2), 11970 lineNumber: lineNumber, 11971 lineStart: lineStart, 11972 start: start, 11973 end: index 11974 }; 11975 } 11976 11977 function scanOctalLiteral(prefix, start) { 11978 var number, octal; 11979 11980 if (isOctalDigit(prefix)) { 11981 octal = true; 11982 number = '0' + source[index++]; 11983 } else { 11984 octal = false; 11985 ++index; 11986 number = ''; 11987 } 11988 11989 while (index < length) { 11990 if (!isOctalDigit(source[index])) { 11991 break; 11992 } 11993 number += source[index++]; 11994 } 11995 11996 if (!octal && number.length === 0) { 11997 // only 0o or 0O 11998 throwUnexpectedToken(); 11999 } 12000 12001 if (isIdentifierStart(source.charCodeAt(index)) || isDecimalDigit(source.charCodeAt(index))) { 12002 throwUnexpectedToken(); 12003 } 12004 12005 return { 12006 type: Token.NumericLiteral, 12007 value: parseInt(number, 8), 12008 octal: octal, 12009 lineNumber: lineNumber, 12010 lineStart: lineStart, 12011 start: start, 12012 end: index 12013 }; 12014 } 12015 12016 function isImplicitOctalLiteral() { 12017 var i, ch; 12018 12019 // Implicit octal, unless there is a non-octal digit. 12020 // (Annex B.1.1 on Numeric Literals) 12021 for (i = index + 1; i < length; ++i) { 12022 ch = source[i]; 12023 if (ch === '8' || ch === '9') { 12024 return false; 12025 } 12026 if (!isOctalDigit(ch)) { 12027 return true; 12028 } 12029 } 12030 12031 return true; 12032 } 12033 12034 function scanNumericLiteral() { 12035 var number, start, ch; 12036 12037 ch = source[index]; 12038 assert(isDecimalDigit(ch.charCodeAt(0)) || (ch === '.'), 12039 'Numeric literal must start with a decimal digit or a decimal point'); 12040 12041 start = index; 12042 number = ''; 12043 if (ch !== '.') { 12044 number = source[index++]; 12045 ch = source[index]; 12046 12047 // Hex number starts with '0x'. 12048 // Octal number starts with '0'. 12049 // Octal number in ES6 starts with '0o'. 12050 // Binary number in ES6 starts with '0b'. 12051 if (number === '0') { 12052 if (ch === 'x' || ch === 'X') { 12053 ++index; 12054 return scanHexLiteral(start); 12055 } 12056 if (ch === 'b' || ch === 'B') { 12057 ++index; 12058 return scanBinaryLiteral(start); 12059 } 12060 if (ch === 'o' || ch === 'O') { 12061 return scanOctalLiteral(ch, start); 12062 } 12063 12064 if (isOctalDigit(ch)) { 12065 if (isImplicitOctalLiteral()) { 12066 return scanOctalLiteral(ch, start); 12067 } 12068 } 12069 } 12070 12071 while (isDecimalDigit(source.charCodeAt(index))) { 12072 number += source[index++]; 12073 } 12074 ch = source[index]; 12075 } 12076 12077 if (ch === '.') { 12078 number += source[index++]; 12079 while (isDecimalDigit(source.charCodeAt(index))) { 12080 number += source[index++]; 12081 } 12082 ch = source[index]; 12083 } 12084 12085 if (ch === 'e' || ch === 'E') { 12086 number += source[index++]; 12087 12088 ch = source[index]; 12089 if (ch === '+' || ch === '-') { 12090 number += source[index++]; 12091 } 12092 if (isDecimalDigit(source.charCodeAt(index))) { 12093 while (isDecimalDigit(source.charCodeAt(index))) { 12094 number += source[index++]; 12095 } 12096 } else { 12097 throwUnexpectedToken(); 12098 } 12099 } 12100 12101 if (isIdentifierStart(source.charCodeAt(index))) { 12102 throwUnexpectedToken(); 12103 } 12104 12105 return { 12106 type: Token.NumericLiteral, 12107 value: parseFloat(number), 12108 lineNumber: lineNumber, 12109 lineStart: lineStart, 12110 start: start, 12111 end: index 12112 }; 12113 } 12114 12115 // ECMA-262 11.8.4 String Literals 12116 12117 function scanStringLiteral() { 12118 var str = '', quote, start, ch, unescaped, octToDec, octal = false; 12119 12120 quote = source[index]; 12121 assert((quote === '\'' || quote === '"'), 12122 'String literal must starts with a quote'); 12123 12124 start = index; 12125 ++index; 12126 12127 while (index < length) { 12128 ch = source[index++]; 12129 12130 if (ch === quote) { 12131 quote = ''; 12132 break; 12133 } else if (ch === '\\') { 12134 ch = source[index++]; 12135 if (!ch || !isLineTerminator(ch.charCodeAt(0))) { 12136 switch (ch) { 12137 case 'u': 12138 case 'x': 12139 if (source[index] === '{') { 12140 ++index; 12141 str += scanUnicodeCodePointEscape(); 12142 } else { 12143 unescaped = scanHexEscape(ch); 12144 if (!unescaped) { 12145 throw throwUnexpectedToken(); 12146 } 12147 str += unescaped; 12148 } 12149 break; 12150 case 'n': 12151 str += '\n'; 12152 break; 12153 case 'r': 12154 str += '\r'; 12155 break; 12156 case 't': 12157 str += '\t'; 12158 break; 12159 case 'b': 12160 str += '\b'; 12161 break; 12162 case 'f': 12163 str += '\f'; 12164 break; 12165 case 'v': 12166 str += '\x0B'; 12167 break; 12168 case '8': 12169 case '9': 12170 str += ch; 12171 tolerateUnexpectedToken(); 12172 break; 12173 12174 default: 12175 if (isOctalDigit(ch)) { 12176 octToDec = octalToDecimal(ch); 12177 12178 octal = octToDec.octal || octal; 12179 str += String.fromCharCode(octToDec.code); 12180 } else { 12181 str += ch; 12182 } 12183 break; 12184 } 12185 } else { 12186 ++lineNumber; 12187 if (ch === '\r' && source[index] === '\n') { 12188 ++index; 12189 } 12190 lineStart = index; 12191 } 12192 } else if (isLineTerminator(ch.charCodeAt(0))) { 12193 break; 12194 } else { 12195 str += ch; 12196 } 12197 } 12198 12199 if (quote !== '') { 12200 throwUnexpectedToken(); 12201 } 12202 12203 return { 12204 type: Token.StringLiteral, 12205 value: str, 12206 octal: octal, 12207 lineNumber: startLineNumber, 12208 lineStart: startLineStart, 12209 start: start, 12210 end: index 12211 }; 12212 } 12213 12214 // ECMA-262 11.8.6 Template Literal Lexical Components 12215 12216 function scanTemplate() { 12217 var cooked = '', ch, start, rawOffset, terminated, head, tail, restore, unescaped; 12218 12219 terminated = false; 12220 tail = false; 12221 start = index; 12222 head = (source[index] === '`'); 12223 rawOffset = 2; 12224 12225 ++index; 12226 12227 while (index < length) { 12228 ch = source[index++]; 12229 if (ch === '`') { 12230 rawOffset = 1; 12231 tail = true; 12232 terminated = true; 12233 break; 12234 } else if (ch === '$') { 12235 if (source[index] === '{') { 12236 state.curlyStack.push('${'); 12237 ++index; 12238 terminated = true; 12239 break; 12240 } 12241 cooked += ch; 12242 } else if (ch === '\\') { 12243 ch = source[index++]; 12244 if (!isLineTerminator(ch.charCodeAt(0))) { 12245 switch (ch) { 12246 case 'n': 12247 cooked += '\n'; 12248 break; 12249 case 'r': 12250 cooked += '\r'; 12251 break; 12252 case 't': 12253 cooked += '\t'; 12254 break; 12255 case 'u': 12256 case 'x': 12257 if (source[index] === '{') { 12258 ++index; 12259 cooked += scanUnicodeCodePointEscape(); 12260 } else { 12261 restore = index; 12262 unescaped = scanHexEscape(ch); 12263 if (unescaped) { 12264 cooked += unescaped; 12265 } else { 12266 index = restore; 12267 cooked += ch; 12268 } 12269 } 12270 break; 12271 case 'b': 12272 cooked += '\b'; 12273 break; 12274 case 'f': 12275 cooked += '\f'; 12276 break; 12277 case 'v': 12278 cooked += '\v'; 12279 break; 12280 12281 default: 12282 if (ch === '0') { 12283 if (isDecimalDigit(source.charCodeAt(index))) { 12284 // Illegal: \01 \02 and so on 12285 throwError(Messages.TemplateOctalLiteral); 12286 } 12287 cooked += '\0'; 12288 } else if (isOctalDigit(ch)) { 12289 // Illegal: \1 \2 12290 throwError(Messages.TemplateOctalLiteral); 12291 } else { 12292 cooked += ch; 12293 } 12294 break; 12295 } 12296 } else { 12297 ++lineNumber; 12298 if (ch === '\r' && source[index] === '\n') { 12299 ++index; 12300 } 12301 lineStart = index; 12302 } 12303 } else if (isLineTerminator(ch.charCodeAt(0))) { 12304 ++lineNumber; 12305 if (ch === '\r' && source[index] === '\n') { 12306 ++index; 12307 } 12308 lineStart = index; 12309 cooked += '\n'; 12310 } else { 12311 cooked += ch; 12312 } 12313 } 12314 12315 if (!terminated) { 12316 throwUnexpectedToken(); 12317 } 12318 12319 if (!head) { 12320 state.curlyStack.pop(); 12321 } 12322 12323 return { 12324 type: Token.Template, 12325 value: { 12326 cooked: cooked, 12327 raw: source.slice(start + 1, index - rawOffset) 12328 }, 12329 head: head, 12330 tail: tail, 12331 lineNumber: lineNumber, 12332 lineStart: lineStart, 12333 start: start, 12334 end: index 12335 }; 12336 } 12337 12338 // ECMA-262 11.8.5 Regular Expression Literals 12339 12340 function testRegExp(pattern, flags) { 12341 // The BMP character to use as a replacement for astral symbols when 12342 // translating an ES6 "u"-flagged pattern to an ES5-compatible 12343 // approximation. 12344 // Note: replacing with '\uFFFF' enables false positives in unlikely 12345 // scenarios. For example, `[\u{1044f}-\u{10440}]` is an invalid 12346 // pattern that would not be detected by this substitution. 12347 var astralSubstitute = '\uFFFF', 12348 tmp = pattern; 12349 12350 if (flags.indexOf('u') >= 0) { 12351 tmp = tmp 12352 // Replace every Unicode escape sequence with the equivalent 12353 // BMP character or a constant ASCII code point in the case of 12354 // astral symbols. (See the above note on `astralSubstitute` 12355 // for more information.) 12356 .replace(/\\u\{([0-9a-fA-F]+)\}|\\u([a-fA-F0-9]{4})/g, function ($0, $1, $2) { 12357 var codePoint = parseInt($1 || $2, 16); 12358 if (codePoint > 0x10FFFF) { 12359 throwUnexpectedToken(null, Messages.InvalidRegExp); 12360 } 12361 if (codePoint <= 0xFFFF) { 12362 return String.fromCharCode(codePoint); 12363 } 12364 return astralSubstitute; 12365 }) 12366 // Replace each paired surrogate with a single ASCII symbol to 12367 // avoid throwing on regular expressions that are only valid in 12368 // combination with the "u" flag. 12369 .replace( 12370 /[\uD800-\uDBFF][\uDC00-\uDFFF]/g, 12371 astralSubstitute 12372 ); 12373 } 12374 12375 // First, detect invalid regular expressions. 12376 try { 12377 RegExp(tmp); 12378 } catch (e) { 12379 throwUnexpectedToken(null, Messages.InvalidRegExp); 12380 } 12381 12382 // Return a regular expression object for this pattern-flag pair, or 12383 // `null` in case the current environment doesn't support the flags it 12384 // uses. 12385 try { 12386 return new RegExp(pattern, flags); 12387 } catch (exception) { 12388 return null; 12389 } 12390 } 12391 12392 function scanRegExpBody() { 12393 var ch, str, classMarker, terminated, body; 12394 12395 ch = source[index]; 12396 assert(ch === '/', 'Regular expression literal must start with a slash'); 12397 str = source[index++]; 12398 12399 classMarker = false; 12400 terminated = false; 12401 while (index < length) { 12402 ch = source[index++]; 12403 str += ch; 12404 if (ch === '\\') { 12405 ch = source[index++]; 12406 // ECMA-262 7.8.5 12407 if (isLineTerminator(ch.charCodeAt(0))) { 12408 throwUnexpectedToken(null, Messages.UnterminatedRegExp); 12409 } 12410 str += ch; 12411 } else if (isLineTerminator(ch.charCodeAt(0))) { 12412 throwUnexpectedToken(null, Messages.UnterminatedRegExp); 12413 } else if (classMarker) { 12414 if (ch === ']') { 12415 classMarker = false; 12416 } 12417 } else { 12418 if (ch === '/') { 12419 terminated = true; 12420 break; 12421 } else if (ch === '[') { 12422 classMarker = true; 12423 } 12424 } 12425 } 12426 12427 if (!terminated) { 12428 throwUnexpectedToken(null, Messages.UnterminatedRegExp); 12429 } 12430 12431 // Exclude leading and trailing slash. 12432 body = str.substr(1, str.length - 2); 12433 return { 12434 value: body, 12435 literal: str 12436 }; 12437 } 12438 12439 function scanRegExpFlags() { 12440 var ch, str, flags, restore; 12441 12442 str = ''; 12443 flags = ''; 12444 while (index < length) { 12445 ch = source[index]; 12446 if (!isIdentifierPart(ch.charCodeAt(0))) { 12447 break; 12448 } 12449 12450 ++index; 12451 if (ch === '\\' && index < length) { 12452 ch = source[index]; 12453 if (ch === 'u') { 12454 ++index; 12455 restore = index; 12456 ch = scanHexEscape('u'); 12457 if (ch) { 12458 flags += ch; 12459 for (str += '\\u'; restore < index; ++restore) { 12460 str += source[restore]; 12461 } 12462 } else { 12463 index = restore; 12464 flags += 'u'; 12465 str += '\\u'; 12466 } 12467 tolerateUnexpectedToken(); 12468 } else { 12469 str += '\\'; 12470 tolerateUnexpectedToken(); 12471 } 12472 } else { 12473 flags += ch; 12474 str += ch; 12475 } 12476 } 12477 12478 return { 12479 value: flags, 12480 literal: str 12481 }; 12482 } 12483 12484 function scanRegExp() { 12485 var start, body, flags, value; 12486 scanning = true; 12487 12488 lookahead = null; 12489 skipComment(); 12490 start = index; 12491 12492 body = scanRegExpBody(); 12493 flags = scanRegExpFlags(); 12494 value = testRegExp(body.value, flags.value); 12495 scanning = false; 12496 if (extra.tokenize) { 12497 return { 12498 type: Token.RegularExpression, 12499 value: value, 12500 regex: { 12501 pattern: body.value, 12502 flags: flags.value 12503 }, 12504 lineNumber: lineNumber, 12505 lineStart: lineStart, 12506 start: start, 12507 end: index 12508 }; 12509 } 12510 12511 return { 12512 literal: body.literal + flags.literal, 12513 value: value, 12514 regex: { 12515 pattern: body.value, 12516 flags: flags.value 12517 }, 12518 start: start, 12519 end: index 12520 }; 12521 } 12522 12523 function collectRegex() { 12524 var pos, loc, regex, token; 12525 12526 skipComment(); 12527 12528 pos = index; 12529 loc = { 12530 start: { 12531 line: lineNumber, 12532 column: index - lineStart 12533 } 12534 }; 12535 12536 regex = scanRegExp(); 12537 12538 loc.end = { 12539 line: lineNumber, 12540 column: index - lineStart 12541 }; 12542 12543 /* istanbul ignore next */ 12544 if (!extra.tokenize) { 12545 // Pop the previous token, which is likely '/' or '/=' 12546 if (extra.tokens.length > 0) { 12547 token = extra.tokens[extra.tokens.length - 1]; 12548 if (token.range[0] === pos && token.type === 'Punctuator') { 12549 if (token.value === '/' || token.value === '/=') { 12550 extra.tokens.pop(); 12551 } 12552 } 12553 } 12554 12555 extra.tokens.push({ 12556 type: 'RegularExpression', 12557 value: regex.literal, 12558 regex: regex.regex, 12559 range: [pos, index], 12560 loc: loc 12561 }); 12562 } 12563 12564 return regex; 12565 } 12566 12567 function isIdentifierName(token) { 12568 return token.type === Token.Identifier || 12569 token.type === Token.Keyword || 12570 token.type === Token.BooleanLiteral || 12571 token.type === Token.NullLiteral; 12572 } 12573 12574 // Using the following algorithm: 12575 // https://github.com/mozilla/sweet.js/wiki/design 12576 12577 function advanceSlash() { 12578 var regex, previous, check; 12579 12580 function testKeyword(value) { 12581 return value && (value.length > 1) && (value[0] >= 'a') && (value[0] <= 'z'); 12582 } 12583 12584 previous = extra.tokenValues[extra.tokens.length - 1]; 12585 regex = (previous !== null); 12586 12587 switch (previous) { 12588 case 'this': 12589 case ']': 12590 regex = false; 12591 break; 12592 12593 case ')': 12594 check = extra.tokenValues[extra.openParenToken - 1]; 12595 regex = (check === 'if' || check === 'while' || check === 'for' || check === 'with'); 12596 break; 12597 12598 case '}': 12599 // Dividing a function by anything makes little sense, 12600 // but we have to check for that. 12601 regex = false; 12602 if (testKeyword(extra.tokenValues[extra.openCurlyToken - 3])) { 12603 // Anonymous function, e.g. function(){} /42 12604 check = extra.tokenValues[extra.openCurlyToken - 4]; 12605 regex = check ? (FnExprTokens.indexOf(check) < 0) : false; 12606 } else if (testKeyword(extra.tokenValues[extra.openCurlyToken - 4])) { 12607 // Named function, e.g. function f(){} /42/ 12608 check = extra.tokenValues[extra.openCurlyToken - 5]; 12609 regex = check ? (FnExprTokens.indexOf(check) < 0) : true; 12610 } 12611 } 12612 12613 return regex ? collectRegex() : scanPunctuator(); 12614 } 12615 12616 function advance() { 12617 var cp, token; 12618 12619 if (index >= length) { 12620 return { 12621 type: Token.EOF, 12622 lineNumber: lineNumber, 12623 lineStart: lineStart, 12624 start: index, 12625 end: index 12626 }; 12627 } 12628 12629 cp = source.charCodeAt(index); 12630 12631 if (isIdentifierStart(cp)) { 12632 token = scanIdentifier(); 12633 if (strict && isStrictModeReservedWord(token.value)) { 12634 token.type = Token.Keyword; 12635 } 12636 return token; 12637 } 12638 12639 // Very common: ( and ) and ; 12640 if (cp === 0x28 || cp === 0x29 || cp === 0x3B) { 12641 return scanPunctuator(); 12642 } 12643 12644 // String literal starts with single quote (U+0027) or double quote (U+0022). 12645 if (cp === 0x27 || cp === 0x22) { 12646 return scanStringLiteral(); 12647 } 12648 12649 // Dot (.) U+002E can also start a floating-point number, hence the need 12650 // to check the next character. 12651 if (cp === 0x2E) { 12652 if (isDecimalDigit(source.charCodeAt(index + 1))) { 12653 return scanNumericLiteral(); 12654 } 12655 return scanPunctuator(); 12656 } 12657 12658 if (isDecimalDigit(cp)) { 12659 return scanNumericLiteral(); 12660 } 12661 12662 // Slash (/) U+002F can also start a regex. 12663 if (extra.tokenize && cp === 0x2F) { 12664 return advanceSlash(); 12665 } 12666 12667 // Template literals start with ` (U+0060) for template head 12668 // or } (U+007D) for template middle or template tail. 12669 if (cp === 0x60 || (cp === 0x7D && state.curlyStack[state.curlyStack.length - 1] === '${')) { 12670 return scanTemplate(); 12671 } 12672 12673 // Possible identifier start in a surrogate pair. 12674 if (cp >= 0xD800 && cp < 0xDFFF) { 12675 cp = codePointAt(index); 12676 if (isIdentifierStart(cp)) { 12677 return scanIdentifier(); 12678 } 12679 } 12680 12681 return scanPunctuator(); 12682 } 12683 12684 function collectToken() { 12685 var loc, token, value, entry; 12686 12687 loc = { 12688 start: { 12689 line: lineNumber, 12690 column: index - lineStart 12691 } 12692 }; 12693 12694 token = advance(); 12695 loc.end = { 12696 line: lineNumber, 12697 column: index - lineStart 12698 }; 12699 12700 if (token.type !== Token.EOF) { 12701 value = source.slice(token.start, token.end); 12702 entry = { 12703 type: TokenName[token.type], 12704 value: value, 12705 range: [token.start, token.end], 12706 loc: loc 12707 }; 12708 if (token.regex) { 12709 entry.regex = { 12710 pattern: token.regex.pattern, 12711 flags: token.regex.flags 12712 }; 12713 } 12714 if (extra.tokenValues) { 12715 extra.tokenValues.push((entry.type === 'Punctuator' || entry.type === 'Keyword') ? entry.value : null); 12716 } 12717 if (extra.tokenize) { 12718 if (!extra.range) { 12719 delete entry.range; 12720 } 12721 if (!extra.loc) { 12722 delete entry.loc; 12723 } 12724 if (extra.delegate) { 12725 entry = extra.delegate(entry); 12726 } 12727 } 12728 extra.tokens.push(entry); 12729 } 12730 12731 return token; 12732 } 12733 12734 function lex() { 12735 var token; 12736 scanning = true; 12737 12738 lastIndex = index; 12739 lastLineNumber = lineNumber; 12740 lastLineStart = lineStart; 12741 12742 skipComment(); 12743 12744 token = lookahead; 12745 12746 startIndex = index; 12747 startLineNumber = lineNumber; 12748 startLineStart = lineStart; 12749 12750 lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance(); 12751 scanning = false; 12752 return token; 12753 } 12754 12755 function peek() { 12756 scanning = true; 12757 12758 skipComment(); 12759 12760 lastIndex = index; 12761 lastLineNumber = lineNumber; 12762 lastLineStart = lineStart; 12763 12764 startIndex = index; 12765 startLineNumber = lineNumber; 12766 startLineStart = lineStart; 12767 12768 lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance(); 12769 scanning = false; 12770 } 12771 12772 function Position() { 12773 this.line = startLineNumber; 12774 this.column = startIndex - startLineStart; 12775 } 12776 12777 function SourceLocation() { 12778 this.start = new Position(); 12779 this.end = null; 12780 } 12781 12782 function WrappingSourceLocation(startToken) { 12783 this.start = { 12784 line: startToken.lineNumber, 12785 column: startToken.start - startToken.lineStart 12786 }; 12787 this.end = null; 12788 } 12789 12790 function Node() { 12791 if (extra.range) { 12792 this.range = [startIndex, 0]; 12793 } 12794 if (extra.loc) { 12795 this.loc = new SourceLocation(); 12796 } 12797 } 12798 12799 function WrappingNode(startToken) { 12800 if (extra.range) { 12801 this.range = [startToken.start, 0]; 12802 } 12803 if (extra.loc) { 12804 this.loc = new WrappingSourceLocation(startToken); 12805 } 12806 } 12807 12808 WrappingNode.prototype = Node.prototype = { 12809 12810 processComment: function () { 12811 var lastChild, 12812 innerComments, 12813 leadingComments, 12814 trailingComments, 12815 bottomRight = extra.bottomRightStack, 12816 i, 12817 comment, 12818 last = bottomRight[bottomRight.length - 1]; 12819 12820 if (this.type === Syntax.Program) { 12821 if (this.body.length > 0) { 12822 return; 12823 } 12824 } 12825 /** 12826 * patch innnerComments for properties empty block 12827 * `function a() {/** comments **\/}` 12828 */ 12829 12830 if (this.type === Syntax.BlockStatement && this.body.length === 0) { 12831 innerComments = []; 12832 for (i = extra.leadingComments.length - 1; i >= 0; --i) { 12833 comment = extra.leadingComments[i]; 12834 if (this.range[1] >= comment.range[1]) { 12835 innerComments.unshift(comment); 12836 extra.leadingComments.splice(i, 1); 12837 extra.trailingComments.splice(i, 1); 12838 } 12839 } 12840 if (innerComments.length) { 12841 this.innerComments = innerComments; 12842 //bottomRight.push(this); 12843 return; 12844 } 12845 } 12846 12847 if (extra.trailingComments.length > 0) { 12848 trailingComments = []; 12849 for (i = extra.trailingComments.length - 1; i >= 0; --i) { 12850 comment = extra.trailingComments[i]; 12851 if (comment.range[0] >= this.range[1]) { 12852 trailingComments.unshift(comment); 12853 extra.trailingComments.splice(i, 1); 12854 } 12855 } 12856 extra.trailingComments = []; 12857 } else { 12858 if (last && last.trailingComments && last.trailingComments[0].range[0] >= this.range[1]) { 12859 trailingComments = last.trailingComments; 12860 delete last.trailingComments; 12861 } 12862 } 12863 12864 // Eating the stack. 12865 while (last && last.range[0] >= this.range[0]) { 12866 lastChild = bottomRight.pop(); 12867 last = bottomRight[bottomRight.length - 1]; 12868 } 12869 12870 if (lastChild) { 12871 if (lastChild.leadingComments) { 12872 leadingComments = []; 12873 for (i = lastChild.leadingComments.length - 1; i >= 0; --i) { 12874 comment = lastChild.leadingComments[i]; 12875 if (comment.range[1] <= this.range[0]) { 12876 leadingComments.unshift(comment); 12877 lastChild.leadingComments.splice(i, 1); 12878 } 12879 } 12880 12881 if (!lastChild.leadingComments.length) { 12882 lastChild.leadingComments = undefined; 12883 } 12884 } 12885 } else if (extra.leadingComments.length > 0) { 12886 leadingComments = []; 12887 for (i = extra.leadingComments.length - 1; i >= 0; --i) { 12888 comment = extra.leadingComments[i]; 12889 if (comment.range[1] <= this.range[0]) { 12890 leadingComments.unshift(comment); 12891 extra.leadingComments.splice(i, 1); 12892 } 12893 } 12894 } 12895 12896 12897 if (leadingComments && leadingComments.length > 0) { 12898 this.leadingComments = leadingComments; 12899 } 12900 if (trailingComments && trailingComments.length > 0) { 12901 this.trailingComments = trailingComments; 12902 } 12903 12904 bottomRight.push(this); 12905 }, 12906 12907 finish: function () { 12908 if (extra.range) { 12909 this.range[1] = lastIndex; 12910 } 12911 if (extra.loc) { 12912 this.loc.end = { 12913 line: lastLineNumber, 12914 column: lastIndex - lastLineStart 12915 }; 12916 if (extra.source) { 12917 this.loc.source = extra.source; 12918 } 12919 } 12920 12921 if (extra.attachComment) { 12922 this.processComment(); 12923 } 12924 }, 12925 12926 finishArrayExpression: function (elements) { 12927 this.type = Syntax.ArrayExpression; 12928 this.elements = elements; 12929 this.finish(); 12930 return this; 12931 }, 12932 12933 finishArrayPattern: function (elements) { 12934 this.type = Syntax.ArrayPattern; 12935 this.elements = elements; 12936 this.finish(); 12937 return this; 12938 }, 12939 12940 finishArrowFunctionExpression: function (params, defaults, body, expression) { 12941 this.type = Syntax.ArrowFunctionExpression; 12942 this.id = null; 12943 this.params = params; 12944 this.defaults = defaults; 12945 this.body = body; 12946 this.generator = false; 12947 this.expression = expression; 12948 this.finish(); 12949 return this; 12950 }, 12951 12952 finishAssignmentExpression: function (operator, left, right) { 12953 this.type = Syntax.AssignmentExpression; 12954 this.operator = operator; 12955 this.left = left; 12956 this.right = right; 12957 this.finish(); 12958 return this; 12959 }, 12960 12961 finishAssignmentPattern: function (left, right) { 12962 this.type = Syntax.AssignmentPattern; 12963 this.left = left; 12964 this.right = right; 12965 this.finish(); 12966 return this; 12967 }, 12968 12969 finishBinaryExpression: function (operator, left, right) { 12970 this.type = (operator === '||' || operator === '&&') ? Syntax.LogicalExpression : Syntax.BinaryExpression; 12971 this.operator = operator; 12972 this.left = left; 12973 this.right = right; 12974 this.finish(); 12975 return this; 12976 }, 12977 12978 finishBlockStatement: function (body) { 12979 this.type = Syntax.BlockStatement; 12980 this.body = body; 12981 this.finish(); 12982 return this; 12983 }, 12984 12985 finishBreakStatement: function (label) { 12986 this.type = Syntax.BreakStatement; 12987 this.label = label; 12988 this.finish(); 12989 return this; 12990 }, 12991 12992 finishCallExpression: function (callee, args) { 12993 this.type = Syntax.CallExpression; 12994 this.callee = callee; 12995 this.arguments = args; 12996 this.finish(); 12997 return this; 12998 }, 12999 13000 finishCatchClause: function (param, body) { 13001 this.type = Syntax.CatchClause; 13002 this.param = param; 13003 this.body = body; 13004 this.finish(); 13005 return this; 13006 }, 13007 13008 finishClassBody: function (body) { 13009 this.type = Syntax.ClassBody; 13010 this.body = body; 13011 this.finish(); 13012 return this; 13013 }, 13014 13015 finishClassDeclaration: function (id, superClass, body) { 13016 this.type = Syntax.ClassDeclaration; 13017 this.id = id; 13018 this.superClass = superClass; 13019 this.body = body; 13020 this.finish(); 13021 return this; 13022 }, 13023 13024 finishClassExpression: function (id, superClass, body) { 13025 this.type = Syntax.ClassExpression; 13026 this.id = id; 13027 this.superClass = superClass; 13028 this.body = body; 13029 this.finish(); 13030 return this; 13031 }, 13032 13033 finishConditionalExpression: function (test, consequent, alternate) { 13034 this.type = Syntax.ConditionalExpression; 13035 this.test = test; 13036 this.consequent = consequent; 13037 this.alternate = alternate; 13038 this.finish(); 13039 return this; 13040 }, 13041 13042 finishContinueStatement: function (label) { 13043 this.type = Syntax.ContinueStatement; 13044 this.label = label; 13045 this.finish(); 13046 return this; 13047 }, 13048 13049 finishDebuggerStatement: function () { 13050 this.type = Syntax.DebuggerStatement; 13051 this.finish(); 13052 return this; 13053 }, 13054 13055 finishDoWhileStatement: function (body, test) { 13056 this.type = Syntax.DoWhileStatement; 13057 this.body = body; 13058 this.test = test; 13059 this.finish(); 13060 return this; 13061 }, 13062 13063 finishEmptyStatement: function () { 13064 this.type = Syntax.EmptyStatement; 13065 this.finish(); 13066 return this; 13067 }, 13068 13069 finishExpressionStatement: function (expression) { 13070 this.type = Syntax.ExpressionStatement; 13071 this.expression = expression; 13072 this.finish(); 13073 return this; 13074 }, 13075 13076 finishForStatement: function (init, test, update, body) { 13077 this.type = Syntax.ForStatement; 13078 this.init = init; 13079 this.test = test; 13080 this.update = update; 13081 this.body = body; 13082 this.finish(); 13083 return this; 13084 }, 13085 13086 finishForOfStatement: function (left, right, body) { 13087 this.type = Syntax.ForOfStatement; 13088 this.left = left; 13089 this.right = right; 13090 this.body = body; 13091 this.finish(); 13092 return this; 13093 }, 13094 13095 finishForInStatement: function (left, right, body) { 13096 this.type = Syntax.ForInStatement; 13097 this.left = left; 13098 this.right = right; 13099 this.body = body; 13100 this.each = false; 13101 this.finish(); 13102 return this; 13103 }, 13104 13105 finishFunctionDeclaration: function (id, params, defaults, body, generator) { 13106 this.type = Syntax.FunctionDeclaration; 13107 this.id = id; 13108 this.params = params; 13109 this.defaults = defaults; 13110 this.body = body; 13111 this.generator = generator; 13112 this.expression = false; 13113 this.finish(); 13114 return this; 13115 }, 13116 13117 finishFunctionExpression: function (id, params, defaults, body, generator) { 13118 this.type = Syntax.FunctionExpression; 13119 this.id = id; 13120 this.params = params; 13121 this.defaults = defaults; 13122 this.body = body; 13123 this.generator = generator; 13124 this.expression = false; 13125 this.finish(); 13126 return this; 13127 }, 13128 13129 finishIdentifier: function (name) { 13130 this.type = Syntax.Identifier; 13131 this.name = name; 13132 this.finish(); 13133 return this; 13134 }, 13135 13136 finishIfStatement: function (test, consequent, alternate) { 13137 this.type = Syntax.IfStatement; 13138 this.test = test; 13139 this.consequent = consequent; 13140 this.alternate = alternate; 13141 this.finish(); 13142 return this; 13143 }, 13144 13145 finishLabeledStatement: function (label, body) { 13146 this.type = Syntax.LabeledStatement; 13147 this.label = label; 13148 this.body = body; 13149 this.finish(); 13150 return this; 13151 }, 13152 13153 finishLiteral: function (token) { 13154 this.type = Syntax.Literal; 13155 this.value = token.value; 13156 this.raw = source.slice(token.start, token.end); 13157 if (token.regex) { 13158 this.regex = token.regex; 13159 } 13160 this.finish(); 13161 return this; 13162 }, 13163 13164 finishMemberExpression: function (accessor, object, property) { 13165 this.type = Syntax.MemberExpression; 13166 this.computed = accessor === '['; 13167 this.object = object; 13168 this.property = property; 13169 this.finish(); 13170 return this; 13171 }, 13172 13173 finishMetaProperty: function (meta, property) { 13174 this.type = Syntax.MetaProperty; 13175 this.meta = meta; 13176 this.property = property; 13177 this.finish(); 13178 return this; 13179 }, 13180 13181 finishNewExpression: function (callee, args) { 13182 this.type = Syntax.NewExpression; 13183 this.callee = callee; 13184 this.arguments = args; 13185 this.finish(); 13186 return this; 13187 }, 13188 13189 finishObjectExpression: function (properties) { 13190 this.type = Syntax.ObjectExpression; 13191 this.properties = properties; 13192 this.finish(); 13193 return this; 13194 }, 13195 13196 finishObjectPattern: function (properties) { 13197 this.type = Syntax.ObjectPattern; 13198 this.properties = properties; 13199 this.finish(); 13200 return this; 13201 }, 13202 13203 finishPostfixExpression: function (operator, argument) { 13204 this.type = Syntax.UpdateExpression; 13205 this.operator = operator; 13206 this.argument = argument; 13207 this.prefix = false; 13208 this.finish(); 13209 return this; 13210 }, 13211 13212 finishProgram: function (body, sourceType) { 13213 this.type = Syntax.Program; 13214 this.body = body; 13215 this.sourceType = sourceType; 13216 this.finish(); 13217 return this; 13218 }, 13219 13220 finishProperty: function (kind, key, computed, value, method, shorthand) { 13221 this.type = Syntax.Property; 13222 this.key = key; 13223 this.computed = computed; 13224 this.value = value; 13225 this.kind = kind; 13226 this.method = method; 13227 this.shorthand = shorthand; 13228 this.finish(); 13229 return this; 13230 }, 13231 13232 finishRestElement: function (argument) { 13233 this.type = Syntax.RestElement; 13234 this.argument = argument; 13235 this.finish(); 13236 return this; 13237 }, 13238 13239 finishReturnStatement: function (argument) { 13240 this.type = Syntax.ReturnStatement; 13241 this.argument = argument; 13242 this.finish(); 13243 return this; 13244 }, 13245 13246 finishSequenceExpression: function (expressions) { 13247 this.type = Syntax.SequenceExpression; 13248 this.expressions = expressions; 13249 this.finish(); 13250 return this; 13251 }, 13252 13253 finishSpreadElement: function (argument) { 13254 this.type = Syntax.SpreadElement; 13255 this.argument = argument; 13256 this.finish(); 13257 return this; 13258 }, 13259 13260 finishSwitchCase: function (test, consequent) { 13261 this.type = Syntax.SwitchCase; 13262 this.test = test; 13263 this.consequent = consequent; 13264 this.finish(); 13265 return this; 13266 }, 13267 13268 finishSuper: function () { 13269 this.type = Syntax.Super; 13270 this.finish(); 13271 return this; 13272 }, 13273 13274 finishSwitchStatement: function (discriminant, cases) { 13275 this.type = Syntax.SwitchStatement; 13276 this.discriminant = discriminant; 13277 this.cases = cases; 13278 this.finish(); 13279 return this; 13280 }, 13281 13282 finishTaggedTemplateExpression: function (tag, quasi) { 13283 this.type = Syntax.TaggedTemplateExpression; 13284 this.tag = tag; 13285 this.quasi = quasi; 13286 this.finish(); 13287 return this; 13288 }, 13289 13290 finishTemplateElement: function (value, tail) { 13291 this.type = Syntax.TemplateElement; 13292 this.value = value; 13293 this.tail = tail; 13294 this.finish(); 13295 return this; 13296 }, 13297 13298 finishTemplateLiteral: function (quasis, expressions) { 13299 this.type = Syntax.TemplateLiteral; 13300 this.quasis = quasis; 13301 this.expressions = expressions; 13302 this.finish(); 13303 return this; 13304 }, 13305 13306 finishThisExpression: function () { 13307 this.type = Syntax.ThisExpression; 13308 this.finish(); 13309 return this; 13310 }, 13311 13312 finishThrowStatement: function (argument) { 13313 this.type = Syntax.ThrowStatement; 13314 this.argument = argument; 13315 this.finish(); 13316 return this; 13317 }, 13318 13319 finishTryStatement: function (block, handler, finalizer) { 13320 this.type = Syntax.TryStatement; 13321 this.block = block; 13322 this.guardedHandlers = []; 13323 this.handlers = handler ? [handler] : []; 13324 this.handler = handler; 13325 this.finalizer = finalizer; 13326 this.finish(); 13327 return this; 13328 }, 13329 13330 finishUnaryExpression: function (operator, argument) { 13331 this.type = (operator === '++' || operator === '--') ? Syntax.UpdateExpression : Syntax.UnaryExpression; 13332 this.operator = operator; 13333 this.argument = argument; 13334 this.prefix = true; 13335 this.finish(); 13336 return this; 13337 }, 13338 13339 finishVariableDeclaration: function (declarations) { 13340 this.type = Syntax.VariableDeclaration; 13341 this.declarations = declarations; 13342 this.kind = 'var'; 13343 this.finish(); 13344 return this; 13345 }, 13346 13347 finishLexicalDeclaration: function (declarations, kind) { 13348 this.type = Syntax.VariableDeclaration; 13349 this.declarations = declarations; 13350 this.kind = kind; 13351 this.finish(); 13352 return this; 13353 }, 13354 13355 finishVariableDeclarator: function (id, init) { 13356 this.type = Syntax.VariableDeclarator; 13357 this.id = id; 13358 this.init = init; 13359 this.finish(); 13360 return this; 13361 }, 13362 13363 finishWhileStatement: function (test, body) { 13364 this.type = Syntax.WhileStatement; 13365 this.test = test; 13366 this.body = body; 13367 this.finish(); 13368 return this; 13369 }, 13370 13371 finishWithStatement: function (object, body) { 13372 this.type = Syntax.WithStatement; 13373 this.object = object; 13374 this.body = body; 13375 this.finish(); 13376 return this; 13377 }, 13378 13379 finishExportSpecifier: function (local, exported) { 13380 this.type = Syntax.ExportSpecifier; 13381 this.exported = exported || local; 13382 this.local = local; 13383 this.finish(); 13384 return this; 13385 }, 13386 13387 finishImportDefaultSpecifier: function (local) { 13388 this.type = Syntax.ImportDefaultSpecifier; 13389 this.local = local; 13390 this.finish(); 13391 return this; 13392 }, 13393 13394 finishImportNamespaceSpecifier: function (local) { 13395 this.type = Syntax.ImportNamespaceSpecifier; 13396 this.local = local; 13397 this.finish(); 13398 return this; 13399 }, 13400 13401 finishExportNamedDeclaration: function (declaration, specifiers, src) { 13402 this.type = Syntax.ExportNamedDeclaration; 13403 this.declaration = declaration; 13404 this.specifiers = specifiers; 13405 this.source = src; 13406 this.finish(); 13407 return this; 13408 }, 13409 13410 finishExportDefaultDeclaration: function (declaration) { 13411 this.type = Syntax.ExportDefaultDeclaration; 13412 this.declaration = declaration; 13413 this.finish(); 13414 return this; 13415 }, 13416 13417 finishExportAllDeclaration: function (src) { 13418 this.type = Syntax.ExportAllDeclaration; 13419 this.source = src; 13420 this.finish(); 13421 return this; 13422 }, 13423 13424 finishImportSpecifier: function (local, imported) { 13425 this.type = Syntax.ImportSpecifier; 13426 this.local = local || imported; 13427 this.imported = imported; 13428 this.finish(); 13429 return this; 13430 }, 13431 13432 finishImportDeclaration: function (specifiers, src) { 13433 this.type = Syntax.ImportDeclaration; 13434 this.specifiers = specifiers; 13435 this.source = src; 13436 this.finish(); 13437 return this; 13438 }, 13439 13440 finishYieldExpression: function (argument, delegate) { 13441 this.type = Syntax.YieldExpression; 13442 this.argument = argument; 13443 this.delegate = delegate; 13444 this.finish(); 13445 return this; 13446 } 13447 }; 13448 13449 13450 function recordError(error) { 13451 var e, existing; 13452 13453 for (e = 0; e < extra.errors.length; e++) { 13454 existing = extra.errors[e]; 13455 // Prevent duplicated error. 13456 /* istanbul ignore next */ 13457 if (existing.index === error.index && existing.message === error.message) { 13458 return; 13459 } 13460 } 13461 13462 extra.errors.push(error); 13463 } 13464 13465 function constructError(msg, column) { 13466 var error = new Error(msg); 13467 try { 13468 throw error; 13469 } catch (base) { 13470 /* istanbul ignore else */ 13471 if (Object.create && Object.defineProperty) { 13472 error = Object.create(base); 13473 Object.defineProperty(error, 'column', { value: column }); 13474 } 13475 } finally { 13476 return error; 13477 } 13478 } 13479 13480 function createError(line, pos, description) { 13481 var msg, column, error; 13482 13483 msg = 'Line ' + line + ': ' + description; 13484 column = pos - (scanning ? lineStart : lastLineStart) + 1; 13485 error = constructError(msg, column); 13486 error.lineNumber = line; 13487 error.description = description; 13488 error.index = pos; 13489 return error; 13490 } 13491 13492 // Throw an exception 13493 13494 function throwError(messageFormat) { 13495 var args, msg; 13496 13497 args = Array.prototype.slice.call(arguments, 1); 13498 msg = messageFormat.replace(/%(\d)/g, 13499 function (whole, idx) { 13500 assert(idx < args.length, 'Message reference must be in range'); 13501 return args[idx]; 13502 } 13503 ); 13504 13505 throw createError(lastLineNumber, lastIndex, msg); 13506 } 13507 13508 function tolerateError(messageFormat) { 13509 var args, msg, error; 13510 13511 args = Array.prototype.slice.call(arguments, 1); 13512 /* istanbul ignore next */ 13513 msg = messageFormat.replace(/%(\d)/g, 13514 function (whole, idx) { 13515 assert(idx < args.length, 'Message reference must be in range'); 13516 return args[idx]; 13517 } 13518 ); 13519 13520 error = createError(lineNumber, lastIndex, msg); 13521 if (extra.errors) { 13522 recordError(error); 13523 } else { 13524 throw error; 13525 } 13526 } 13527 13528 // Throw an exception because of the token. 13529 13530 function unexpectedTokenError(token, message) { 13531 var value, msg = message || Messages.UnexpectedToken; 13532 13533 if (token) { 13534 if (!message) { 13535 msg = (token.type === Token.EOF) ? Messages.UnexpectedEOS : 13536 (token.type === Token.Identifier) ? Messages.UnexpectedIdentifier : 13537 (token.type === Token.NumericLiteral) ? Messages.UnexpectedNumber : 13538 (token.type === Token.StringLiteral) ? Messages.UnexpectedString : 13539 (token.type === Token.Template) ? Messages.UnexpectedTemplate : 13540 Messages.UnexpectedToken; 13541 13542 if (token.type === Token.Keyword) { 13543 if (isFutureReservedWord(token.value)) { 13544 msg = Messages.UnexpectedReserved; 13545 } else if (strict && isStrictModeReservedWord(token.value)) { 13546 msg = Messages.StrictReservedWord; 13547 } 13548 } 13549 } 13550 13551 value = (token.type === Token.Template) ? token.value.raw : token.value; 13552 } else { 13553 value = 'ILLEGAL'; 13554 } 13555 13556 msg = msg.replace('%0', value); 13557 13558 return (token && typeof token.lineNumber === 'number') ? 13559 createError(token.lineNumber, token.start, msg) : 13560 createError(scanning ? lineNumber : lastLineNumber, scanning ? index : lastIndex, msg); 13561 } 13562 13563 function throwUnexpectedToken(token, message) { 13564 throw unexpectedTokenError(token, message); 13565 } 13566 13567 function tolerateUnexpectedToken(token, message) { 13568 var error = unexpectedTokenError(token, message); 13569 if (extra.errors) { 13570 recordError(error); 13571 } else { 13572 throw error; 13573 } 13574 } 13575 13576 // Expect the next token to match the specified punctuator. 13577 // If not, an exception will be thrown. 13578 13579 function expect(value) { 13580 var token = lex(); 13581 if (token.type !== Token.Punctuator || token.value !== value) { 13582 throwUnexpectedToken(token); 13583 } 13584 } 13585 13586 /** 13587 * @name expectCommaSeparator 13588 * @description Quietly expect a comma when in tolerant mode, otherwise delegates 13589 * to <code>expect(value)</code> 13590 * @since 2.0 13591 */ 13592 function expectCommaSeparator() { 13593 var token; 13594 13595 if (extra.errors) { 13596 token = lookahead; 13597 if (token.type === Token.Punctuator && token.value === ',') { 13598 lex(); 13599 } else if (token.type === Token.Punctuator && token.value === ';') { 13600 lex(); 13601 tolerateUnexpectedToken(token); 13602 } else { 13603 tolerateUnexpectedToken(token, Messages.UnexpectedToken); 13604 } 13605 } else { 13606 expect(','); 13607 } 13608 } 13609 13610 // Expect the next token to match the specified keyword. 13611 // If not, an exception will be thrown. 13612 13613 function expectKeyword(keyword) { 13614 var token = lex(); 13615 if (token.type !== Token.Keyword || token.value !== keyword) { 13616 throwUnexpectedToken(token); 13617 } 13618 } 13619 13620 // Return true if the next token matches the specified punctuator. 13621 13622 function match(value) { 13623 return lookahead.type === Token.Punctuator && lookahead.value === value; 13624 } 13625 13626 // Return true if the next token matches the specified keyword 13627 13628 function matchKeyword(keyword) { 13629 return lookahead.type === Token.Keyword && lookahead.value === keyword; 13630 } 13631 13632 // Return true if the next token matches the specified contextual keyword 13633 // (where an identifier is sometimes a keyword depending on the context) 13634 13635 function matchContextualKeyword(keyword) { 13636 return lookahead.type === Token.Identifier && lookahead.value === keyword; 13637 } 13638 13639 // Return true if the next token is an assignment operator 13640 13641 function matchAssign() { 13642 var op; 13643 13644 if (lookahead.type !== Token.Punctuator) { 13645 return false; 13646 } 13647 op = lookahead.value; 13648 return op === '=' || 13649 op === '*=' || 13650 op === '/=' || 13651 op === '%=' || 13652 op === '+=' || 13653 op === '-=' || 13654 op === '<<=' || 13655 op === '>>=' || 13656 op === '>>>=' || 13657 op === '&=' || 13658 op === '^=' || 13659 op === '|='; 13660 } 13661 13662 function consumeSemicolon() { 13663 // Catch the very common case first: immediately a semicolon (U+003B). 13664 if (source.charCodeAt(startIndex) === 0x3B || match(';')) { 13665 lex(); 13666 return; 13667 } 13668 13669 if (hasLineTerminator) { 13670 return; 13671 } 13672 13673 // FIXME(ikarienator): this is seemingly an issue in the previous location info convention. 13674 lastIndex = startIndex; 13675 lastLineNumber = startLineNumber; 13676 lastLineStart = startLineStart; 13677 13678 if (lookahead.type !== Token.EOF && !match('}')) { 13679 throwUnexpectedToken(lookahead); 13680 } 13681 } 13682 13683 // Cover grammar support. 13684 // 13685 // When an assignment expression position starts with an left parenthesis, the determination of the type 13686 // of the syntax is to be deferred arbitrarily long until the end of the parentheses pair (plus a lookahead) 13687 // or the first comma. This situation also defers the determination of all the expressions nested in the pair. 13688 // 13689 // There are three productions that can be parsed in a parentheses pair that needs to be determined 13690 // after the outermost pair is closed. They are: 13691 // 13692 // 1. AssignmentExpression 13693 // 2. BindingElements 13694 // 3. AssignmentTargets 13695 // 13696 // In order to avoid exponential backtracking, we use two flags to denote if the production can be 13697 // binding element or assignment target. 13698 // 13699 // The three productions have the relationship: 13700 // 13701 // BindingElements ⊆ AssignmentTargets ⊆ AssignmentExpression 13702 // 13703 // with a single exception that CoverInitializedName when used directly in an Expression, generates 13704 // an early error. Therefore, we need the third state, firstCoverInitializedNameError, to track the 13705 // first usage of CoverInitializedName and report it when we reached the end of the parentheses pair. 13706 // 13707 // isolateCoverGrammar function runs the given parser function with a new cover grammar context, and it does not 13708 // effect the current flags. This means the production the parser parses is only used as an expression. Therefore 13709 // the CoverInitializedName check is conducted. 13710 // 13711 // inheritCoverGrammar function runs the given parse function with a new cover grammar context, and it propagates 13712 // the flags outside of the parser. This means the production the parser parses is used as a part of a potential 13713 // pattern. The CoverInitializedName check is deferred. 13714 function isolateCoverGrammar(parser) { 13715 var oldIsBindingElement = isBindingElement, 13716 oldIsAssignmentTarget = isAssignmentTarget, 13717 oldFirstCoverInitializedNameError = firstCoverInitializedNameError, 13718 result; 13719 isBindingElement = true; 13720 isAssignmentTarget = true; 13721 firstCoverInitializedNameError = null; 13722 result = parser(); 13723 if (firstCoverInitializedNameError !== null) { 13724 throwUnexpectedToken(firstCoverInitializedNameError); 13725 } 13726 isBindingElement = oldIsBindingElement; 13727 isAssignmentTarget = oldIsAssignmentTarget; 13728 firstCoverInitializedNameError = oldFirstCoverInitializedNameError; 13729 return result; 13730 } 13731 13732 function inheritCoverGrammar(parser) { 13733 var oldIsBindingElement = isBindingElement, 13734 oldIsAssignmentTarget = isAssignmentTarget, 13735 oldFirstCoverInitializedNameError = firstCoverInitializedNameError, 13736 result; 13737 isBindingElement = true; 13738 isAssignmentTarget = true; 13739 firstCoverInitializedNameError = null; 13740 result = parser(); 13741 isBindingElement = isBindingElement && oldIsBindingElement; 13742 isAssignmentTarget = isAssignmentTarget && oldIsAssignmentTarget; 13743 firstCoverInitializedNameError = oldFirstCoverInitializedNameError || firstCoverInitializedNameError; 13744 return result; 13745 } 13746 13747 // ECMA-262 13.3.3 Destructuring Binding Patterns 13748 13749 function parseArrayPattern(params, kind) { 13750 var node = new Node(), elements = [], rest, restNode; 13751 expect('['); 13752 13753 while (!match(']')) { 13754 if (match(',')) { 13755 lex(); 13756 elements.push(null); 13757 } else { 13758 if (match('...')) { 13759 restNode = new Node(); 13760 lex(); 13761 params.push(lookahead); 13762 rest = parseVariableIdentifier(kind); 13763 elements.push(restNode.finishRestElement(rest)); 13764 break; 13765 } else { 13766 elements.push(parsePatternWithDefault(params, kind)); 13767 } 13768 if (!match(']')) { 13769 expect(','); 13770 } 13771 } 13772 13773 } 13774 13775 expect(']'); 13776 13777 return node.finishArrayPattern(elements); 13778 } 13779 13780 function parsePropertyPattern(params, kind) { 13781 var node = new Node(), key, keyToken, computed = match('['), init; 13782 if (lookahead.type === Token.Identifier) { 13783 keyToken = lookahead; 13784 key = parseVariableIdentifier(); 13785 if (match('=')) { 13786 params.push(keyToken); 13787 lex(); 13788 init = parseAssignmentExpression(); 13789 13790 return node.finishProperty( 13791 'init', key, false, 13792 new WrappingNode(keyToken).finishAssignmentPattern(key, init), false, false); 13793 } else if (!match(':')) { 13794 params.push(keyToken); 13795 return node.finishProperty('init', key, false, key, false, true); 13796 } 13797 } else { 13798 key = parseObjectPropertyKey(); 13799 } 13800 expect(':'); 13801 init = parsePatternWithDefault(params, kind); 13802 return node.finishProperty('init', key, computed, init, false, false); 13803 } 13804 13805 function parseObjectPattern(params, kind) { 13806 var node = new Node(), properties = []; 13807 13808 expect('{'); 13809 13810 while (!match('}')) { 13811 properties.push(parsePropertyPattern(params, kind)); 13812 if (!match('}')) { 13813 expect(','); 13814 } 13815 } 13816 13817 lex(); 13818 13819 return node.finishObjectPattern(properties); 13820 } 13821 13822 function parsePattern(params, kind) { 13823 if (match('[')) { 13824 return parseArrayPattern(params, kind); 13825 } else if (match('{')) { 13826 return parseObjectPattern(params, kind); 13827 } else if (matchKeyword('let')) { 13828 if (kind === 'const' || kind === 'let') { 13829 tolerateUnexpectedToken(lookahead, Messages.UnexpectedToken); 13830 } 13831 } 13832 13833 params.push(lookahead); 13834 return parseVariableIdentifier(kind); 13835 } 13836 13837 function parsePatternWithDefault(params, kind) { 13838 var startToken = lookahead, pattern, previousAllowYield, right; 13839 pattern = parsePattern(params, kind); 13840 if (match('=')) { 13841 lex(); 13842 previousAllowYield = state.allowYield; 13843 state.allowYield = true; 13844 right = isolateCoverGrammar(parseAssignmentExpression); 13845 state.allowYield = previousAllowYield; 13846 pattern = new WrappingNode(startToken).finishAssignmentPattern(pattern, right); 13847 } 13848 return pattern; 13849 } 13850 13851 // ECMA-262 12.2.5 Array Initializer 13852 13853 function parseArrayInitializer() { 13854 var elements = [], node = new Node(), restSpread; 13855 13856 expect('['); 13857 13858 while (!match(']')) { 13859 if (match(',')) { 13860 lex(); 13861 elements.push(null); 13862 } else if (match('...')) { 13863 restSpread = new Node(); 13864 lex(); 13865 restSpread.finishSpreadElement(inheritCoverGrammar(parseAssignmentExpression)); 13866 13867 if (!match(']')) { 13868 isAssignmentTarget = isBindingElement = false; 13869 expect(','); 13870 } 13871 elements.push(restSpread); 13872 } else { 13873 elements.push(inheritCoverGrammar(parseAssignmentExpression)); 13874 13875 if (!match(']')) { 13876 expect(','); 13877 } 13878 } 13879 } 13880 13881 lex(); 13882 13883 return node.finishArrayExpression(elements); 13884 } 13885 13886 // ECMA-262 12.2.6 Object Initializer 13887 13888 function parsePropertyFunction(node, paramInfo, isGenerator) { 13889 var previousStrict, body; 13890 13891 isAssignmentTarget = isBindingElement = false; 13892 13893 previousStrict = strict; 13894 body = isolateCoverGrammar(parseFunctionSourceElements); 13895 13896 if (strict && paramInfo.firstRestricted) { 13897 tolerateUnexpectedToken(paramInfo.firstRestricted, paramInfo.message); 13898 } 13899 if (strict && paramInfo.stricted) { 13900 tolerateUnexpectedToken(paramInfo.stricted, paramInfo.message); 13901 } 13902 13903 strict = previousStrict; 13904 return node.finishFunctionExpression(null, paramInfo.params, paramInfo.defaults, body, isGenerator); 13905 } 13906 13907 function parsePropertyMethodFunction() { 13908 var params, method, node = new Node(), 13909 previousAllowYield = state.allowYield; 13910 13911 state.allowYield = false; 13912 params = parseParams(); 13913 state.allowYield = previousAllowYield; 13914 13915 state.allowYield = false; 13916 method = parsePropertyFunction(node, params, false); 13917 state.allowYield = previousAllowYield; 13918 13919 return method; 13920 } 13921 13922 function parseObjectPropertyKey() { 13923 var token, node = new Node(), expr; 13924 13925 token = lex(); 13926 13927 // Note: This function is called only from parseObjectProperty(), where 13928 // EOF and Punctuator tokens are already filtered out. 13929 13930 switch (token.type) { 13931 case Token.StringLiteral: 13932 case Token.NumericLiteral: 13933 if (strict && token.octal) { 13934 tolerateUnexpectedToken(token, Messages.StrictOctalLiteral); 13935 } 13936 return node.finishLiteral(token); 13937 case Token.Identifier: 13938 case Token.BooleanLiteral: 13939 case Token.NullLiteral: 13940 case Token.Keyword: 13941 return node.finishIdentifier(token.value); 13942 case Token.Punctuator: 13943 if (token.value === '[') { 13944 expr = isolateCoverGrammar(parseAssignmentExpression); 13945 expect(']'); 13946 return expr; 13947 } 13948 break; 13949 } 13950 throwUnexpectedToken(token); 13951 } 13952 13953 function lookaheadPropertyName() { 13954 switch (lookahead.type) { 13955 case Token.Identifier: 13956 case Token.StringLiteral: 13957 case Token.BooleanLiteral: 13958 case Token.NullLiteral: 13959 case Token.NumericLiteral: 13960 case Token.Keyword: 13961 return true; 13962 case Token.Punctuator: 13963 return lookahead.value === '['; 13964 } 13965 return false; 13966 } 13967 13968 // This function is to try to parse a MethodDefinition as defined in 14.3. But in the case of object literals, 13969 // it might be called at a position where there is in fact a short hand identifier pattern or a data property. 13970 // This can only be determined after we consumed up to the left parentheses. 13971 // 13972 // In order to avoid back tracking, it returns `null` if the position is not a MethodDefinition and the caller 13973 // is responsible to visit other options. 13974 function tryParseMethodDefinition(token, key, computed, node) { 13975 var value, options, methodNode, params, 13976 previousAllowYield = state.allowYield; 13977 13978 if (token.type === Token.Identifier) { 13979 // check for `get` and `set`; 13980 13981 if (token.value === 'get' && lookaheadPropertyName()) { 13982 computed = match('['); 13983 key = parseObjectPropertyKey(); 13984 methodNode = new Node(); 13985 expect('('); 13986 expect(')'); 13987 13988 state.allowYield = false; 13989 value = parsePropertyFunction(methodNode, { 13990 params: [], 13991 defaults: [], 13992 stricted: null, 13993 firstRestricted: null, 13994 message: null 13995 }, false); 13996 state.allowYield = previousAllowYield; 13997 13998 return node.finishProperty('get', key, computed, value, false, false); 13999 } else if (token.value === 'set' && lookaheadPropertyName()) { 14000 computed = match('['); 14001 key = parseObjectPropertyKey(); 14002 methodNode = new Node(); 14003 expect('('); 14004 14005 options = { 14006 params: [], 14007 defaultCount: 0, 14008 defaults: [], 14009 firstRestricted: null, 14010 paramSet: {} 14011 }; 14012 if (match(')')) { 14013 tolerateUnexpectedToken(lookahead); 14014 } else { 14015 state.allowYield = false; 14016 parseParam(options); 14017 state.allowYield = previousAllowYield; 14018 if (options.defaultCount === 0) { 14019 options.defaults = []; 14020 } 14021 } 14022 expect(')'); 14023 14024 state.allowYield = false; 14025 value = parsePropertyFunction(methodNode, options, false); 14026 state.allowYield = previousAllowYield; 14027 14028 return node.finishProperty('set', key, computed, value, false, false); 14029 } 14030 } else if (token.type === Token.Punctuator && token.value === '*' && lookaheadPropertyName()) { 14031 computed = match('['); 14032 key = parseObjectPropertyKey(); 14033 methodNode = new Node(); 14034 14035 state.allowYield = true; 14036 params = parseParams(); 14037 state.allowYield = previousAllowYield; 14038 14039 state.allowYield = false; 14040 value = parsePropertyFunction(methodNode, params, true); 14041 state.allowYield = previousAllowYield; 14042 14043 return node.finishProperty('init', key, computed, value, true, false); 14044 } 14045 14046 if (key && match('(')) { 14047 value = parsePropertyMethodFunction(); 14048 return node.finishProperty('init', key, computed, value, true, false); 14049 } 14050 14051 // Not a MethodDefinition. 14052 return null; 14053 } 14054 14055 function parseObjectProperty(hasProto) { 14056 var token = lookahead, node = new Node(), computed, key, maybeMethod, proto, value; 14057 14058 computed = match('['); 14059 if (match('*')) { 14060 lex(); 14061 } else { 14062 key = parseObjectPropertyKey(); 14063 } 14064 maybeMethod = tryParseMethodDefinition(token, key, computed, node); 14065 if (maybeMethod) { 14066 return maybeMethod; 14067 } 14068 14069 if (!key) { 14070 throwUnexpectedToken(lookahead); 14071 } 14072 14073 // Check for duplicated __proto__ 14074 if (!computed) { 14075 proto = (key.type === Syntax.Identifier && key.name === '__proto__') || 14076 (key.type === Syntax.Literal && key.value === '__proto__'); 14077 if (hasProto.value && proto) { 14078 tolerateError(Messages.DuplicateProtoProperty); 14079 } 14080 hasProto.value |= proto; 14081 } 14082 14083 if (match(':')) { 14084 lex(); 14085 value = inheritCoverGrammar(parseAssignmentExpression); 14086 return node.finishProperty('init', key, computed, value, false, false); 14087 } 14088 14089 if (token.type === Token.Identifier) { 14090 if (match('=')) { 14091 firstCoverInitializedNameError = lookahead; 14092 lex(); 14093 value = isolateCoverGrammar(parseAssignmentExpression); 14094 return node.finishProperty('init', key, computed, 14095 new WrappingNode(token).finishAssignmentPattern(key, value), false, true); 14096 } 14097 return node.finishProperty('init', key, computed, key, false, true); 14098 } 14099 14100 throwUnexpectedToken(lookahead); 14101 } 14102 14103 function parseObjectInitializer() { 14104 var properties = [], hasProto = {value: false}, node = new Node(); 14105 14106 expect('{'); 14107 14108 while (!match('}')) { 14109 properties.push(parseObjectProperty(hasProto)); 14110 14111 if (!match('}')) { 14112 expectCommaSeparator(); 14113 } 14114 } 14115 14116 expect('}'); 14117 14118 return node.finishObjectExpression(properties); 14119 } 14120 14121 function reinterpretExpressionAsPattern(expr) { 14122 var i; 14123 switch (expr.type) { 14124 case Syntax.Identifier: 14125 case Syntax.MemberExpression: 14126 case Syntax.RestElement: 14127 case Syntax.AssignmentPattern: 14128 break; 14129 case Syntax.SpreadElement: 14130 expr.type = Syntax.RestElement; 14131 reinterpretExpressionAsPattern(expr.argument); 14132 break; 14133 case Syntax.ArrayExpression: 14134 expr.type = Syntax.ArrayPattern; 14135 for (i = 0; i < expr.elements.length; i++) { 14136 if (expr.elements[i] !== null) { 14137 reinterpretExpressionAsPattern(expr.elements[i]); 14138 } 14139 } 14140 break; 14141 case Syntax.ObjectExpression: 14142 expr.type = Syntax.ObjectPattern; 14143 for (i = 0; i < expr.properties.length; i++) { 14144 reinterpretExpressionAsPattern(expr.properties[i].value); 14145 } 14146 break; 14147 case Syntax.AssignmentExpression: 14148 expr.type = Syntax.AssignmentPattern; 14149 reinterpretExpressionAsPattern(expr.left); 14150 break; 14151 default: 14152 // Allow other node type for tolerant parsing. 14153 break; 14154 } 14155 } 14156 14157 // ECMA-262 12.2.9 Template Literals 14158 14159 function parseTemplateElement(option) { 14160 var node, token; 14161 14162 if (lookahead.type !== Token.Template || (option.head && !lookahead.head)) { 14163 throwUnexpectedToken(); 14164 } 14165 14166 node = new Node(); 14167 token = lex(); 14168 14169 return node.finishTemplateElement({ raw: token.value.raw, cooked: token.value.cooked }, token.tail); 14170 } 14171 14172 function parseTemplateLiteral() { 14173 var quasi, quasis, expressions, node = new Node(); 14174 14175 quasi = parseTemplateElement({ head: true }); 14176 quasis = [quasi]; 14177 expressions = []; 14178 14179 while (!quasi.tail) { 14180 expressions.push(parseExpression()); 14181 quasi = parseTemplateElement({ head: false }); 14182 quasis.push(quasi); 14183 } 14184 14185 return node.finishTemplateLiteral(quasis, expressions); 14186 } 14187 14188 // ECMA-262 12.2.10 The Grouping Operator 14189 14190 function parseGroupExpression() { 14191 var expr, expressions, startToken, i, params = []; 14192 14193 expect('('); 14194 14195 if (match(')')) { 14196 lex(); 14197 if (!match('=>')) { 14198 expect('=>'); 14199 } 14200 return { 14201 type: PlaceHolders.ArrowParameterPlaceHolder, 14202 params: [], 14203 rawParams: [] 14204 }; 14205 } 14206 14207 startToken = lookahead; 14208 if (match('...')) { 14209 expr = parseRestElement(params); 14210 expect(')'); 14211 if (!match('=>')) { 14212 expect('=>'); 14213 } 14214 return { 14215 type: PlaceHolders.ArrowParameterPlaceHolder, 14216 params: [expr] 14217 }; 14218 } 14219 14220 isBindingElement = true; 14221 expr = inheritCoverGrammar(parseAssignmentExpression); 14222 14223 if (match(',')) { 14224 isAssignmentTarget = false; 14225 expressions = [expr]; 14226 14227 while (startIndex < length) { 14228 if (!match(',')) { 14229 break; 14230 } 14231 lex(); 14232 14233 if (match('...')) { 14234 if (!isBindingElement) { 14235 throwUnexpectedToken(lookahead); 14236 } 14237 expressions.push(parseRestElement(params)); 14238 expect(')'); 14239 if (!match('=>')) { 14240 expect('=>'); 14241 } 14242 isBindingElement = false; 14243 for (i = 0; i < expressions.length; i++) { 14244 reinterpretExpressionAsPattern(expressions[i]); 14245 } 14246 return { 14247 type: PlaceHolders.ArrowParameterPlaceHolder, 14248 params: expressions 14249 }; 14250 } 14251 14252 expressions.push(inheritCoverGrammar(parseAssignmentExpression)); 14253 } 14254 14255 expr = new WrappingNode(startToken).finishSequenceExpression(expressions); 14256 } 14257 14258 14259 expect(')'); 14260 14261 if (match('=>')) { 14262 if (expr.type === Syntax.Identifier && expr.name === 'yield') { 14263 return { 14264 type: PlaceHolders.ArrowParameterPlaceHolder, 14265 params: [expr] 14266 }; 14267 } 14268 14269 if (!isBindingElement) { 14270 throwUnexpectedToken(lookahead); 14271 } 14272 14273 if (expr.type === Syntax.SequenceExpression) { 14274 for (i = 0; i < expr.expressions.length; i++) { 14275 reinterpretExpressionAsPattern(expr.expressions[i]); 14276 } 14277 } else { 14278 reinterpretExpressionAsPattern(expr); 14279 } 14280 14281 expr = { 14282 type: PlaceHolders.ArrowParameterPlaceHolder, 14283 params: expr.type === Syntax.SequenceExpression ? expr.expressions : [expr] 14284 }; 14285 } 14286 isBindingElement = false; 14287 return expr; 14288 } 14289 14290 14291 // ECMA-262 12.2 Primary Expressions 14292 14293 function parsePrimaryExpression() { 14294 var type, token, expr, node; 14295 14296 if (match('(')) { 14297 isBindingElement = false; 14298 return inheritCoverGrammar(parseGroupExpression); 14299 } 14300 14301 if (match('[')) { 14302 return inheritCoverGrammar(parseArrayInitializer); 14303 } 14304 14305 if (match('{')) { 14306 return inheritCoverGrammar(parseObjectInitializer); 14307 } 14308 14309 type = lookahead.type; 14310 node = new Node(); 14311 14312 if (type === Token.Identifier) { 14313 if (state.sourceType === 'module' && lookahead.value === 'await') { 14314 tolerateUnexpectedToken(lookahead); 14315 } 14316 expr = node.finishIdentifier(lex().value); 14317 } else if (type === Token.StringLiteral || type === Token.NumericLiteral) { 14318 isAssignmentTarget = isBindingElement = false; 14319 if (strict && lookahead.octal) { 14320 tolerateUnexpectedToken(lookahead, Messages.StrictOctalLiteral); 14321 } 14322 expr = node.finishLiteral(lex()); 14323 } else if (type === Token.Keyword) { 14324 if (!strict && state.allowYield && matchKeyword('yield')) { 14325 return parseNonComputedProperty(); 14326 } 14327 if (!strict && matchKeyword('let')) { 14328 return node.finishIdentifier(lex().value); 14329 } 14330 isAssignmentTarget = isBindingElement = false; 14331 if (matchKeyword('function')) { 14332 return parseFunctionExpression(); 14333 } 14334 if (matchKeyword('this')) { 14335 lex(); 14336 return node.finishThisExpression(); 14337 } 14338 if (matchKeyword('class')) { 14339 return parseClassExpression(); 14340 } 14341 throwUnexpectedToken(lex()); 14342 } else if (type === Token.BooleanLiteral) { 14343 isAssignmentTarget = isBindingElement = false; 14344 token = lex(); 14345 token.value = (token.value === 'true'); 14346 expr = node.finishLiteral(token); 14347 } else if (type === Token.NullLiteral) { 14348 isAssignmentTarget = isBindingElement = false; 14349 token = lex(); 14350 token.value = null; 14351 expr = node.finishLiteral(token); 14352 } else if (match('/') || match('/=')) { 14353 isAssignmentTarget = isBindingElement = false; 14354 index = startIndex; 14355 14356 if (typeof extra.tokens !== 'undefined') { 14357 token = collectRegex(); 14358 } else { 14359 token = scanRegExp(); 14360 } 14361 lex(); 14362 expr = node.finishLiteral(token); 14363 } else if (type === Token.Template) { 14364 expr = parseTemplateLiteral(); 14365 } else { 14366 throwUnexpectedToken(lex()); 14367 } 14368 14369 return expr; 14370 } 14371 14372 // ECMA-262 12.3 Left-Hand-Side Expressions 14373 14374 function parseArguments() { 14375 var args = [], expr; 14376 14377 expect('('); 14378 14379 if (!match(')')) { 14380 while (startIndex < length) { 14381 if (match('...')) { 14382 expr = new Node(); 14383 lex(); 14384 expr.finishSpreadElement(isolateCoverGrammar(parseAssignmentExpression)); 14385 } else { 14386 expr = isolateCoverGrammar(parseAssignmentExpression); 14387 } 14388 args.push(expr); 14389 if (match(')')) { 14390 break; 14391 } 14392 expectCommaSeparator(); 14393 } 14394 } 14395 14396 expect(')'); 14397 14398 return args; 14399 } 14400 14401 function parseNonComputedProperty() { 14402 var token, node = new Node(); 14403 14404 token = lex(); 14405 14406 if (!isIdentifierName(token)) { 14407 throwUnexpectedToken(token); 14408 } 14409 14410 return node.finishIdentifier(token.value); 14411 } 14412 14413 function parseNonComputedMember() { 14414 expect('.'); 14415 14416 return parseNonComputedProperty(); 14417 } 14418 14419 function parseComputedMember() { 14420 var expr; 14421 14422 expect('['); 14423 14424 expr = isolateCoverGrammar(parseExpression); 14425 14426 expect(']'); 14427 14428 return expr; 14429 } 14430 14431 // ECMA-262 12.3.3 The new Operator 14432 14433 function parseNewExpression() { 14434 var callee, args, node = new Node(); 14435 14436 expectKeyword('new'); 14437 14438 if (match('.')) { 14439 lex(); 14440 if (lookahead.type === Token.Identifier && lookahead.value === 'target') { 14441 if (state.inFunctionBody) { 14442 lex(); 14443 return node.finishMetaProperty('new', 'target'); 14444 } 14445 } 14446 throwUnexpectedToken(lookahead); 14447 } 14448 14449 callee = isolateCoverGrammar(parseLeftHandSideExpression); 14450 args = match('(') ? parseArguments() : []; 14451 14452 isAssignmentTarget = isBindingElement = false; 14453 14454 return node.finishNewExpression(callee, args); 14455 } 14456 14457 // ECMA-262 12.3.4 Function Calls 14458 14459 function parseLeftHandSideExpressionAllowCall() { 14460 var quasi, expr, args, property, startToken, previousAllowIn = state.allowIn; 14461 14462 startToken = lookahead; 14463 state.allowIn = true; 14464 14465 if (matchKeyword('super') && state.inFunctionBody) { 14466 expr = new Node(); 14467 lex(); 14468 expr = expr.finishSuper(); 14469 if (!match('(') && !match('.') && !match('[')) { 14470 throwUnexpectedToken(lookahead); 14471 } 14472 } else { 14473 expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression); 14474 } 14475 14476 for (;;) { 14477 if (match('.')) { 14478 isBindingElement = false; 14479 isAssignmentTarget = true; 14480 property = parseNonComputedMember(); 14481 expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property); 14482 } else if (match('(')) { 14483 isBindingElement = false; 14484 isAssignmentTarget = false; 14485 args = parseArguments(); 14486 expr = new WrappingNode(startToken).finishCallExpression(expr, args); 14487 } else if (match('[')) { 14488 isBindingElement = false; 14489 isAssignmentTarget = true; 14490 property = parseComputedMember(); 14491 expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property); 14492 } else if (lookahead.type === Token.Template && lookahead.head) { 14493 quasi = parseTemplateLiteral(); 14494 expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi); 14495 } else { 14496 break; 14497 } 14498 } 14499 state.allowIn = previousAllowIn; 14500 14501 return expr; 14502 } 14503 14504 // ECMA-262 12.3 Left-Hand-Side Expressions 14505 14506 function parseLeftHandSideExpression() { 14507 var quasi, expr, property, startToken; 14508 assert(state.allowIn, 'callee of new expression always allow in keyword.'); 14509 14510 startToken = lookahead; 14511 14512 if (matchKeyword('super') && state.inFunctionBody) { 14513 expr = new Node(); 14514 lex(); 14515 expr = expr.finishSuper(); 14516 if (!match('[') && !match('.')) { 14517 throwUnexpectedToken(lookahead); 14518 } 14519 } else { 14520 expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression); 14521 } 14522 14523 for (;;) { 14524 if (match('[')) { 14525 isBindingElement = false; 14526 isAssignmentTarget = true; 14527 property = parseComputedMember(); 14528 expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property); 14529 } else if (match('.')) { 14530 isBindingElement = false; 14531 isAssignmentTarget = true; 14532 property = parseNonComputedMember(); 14533 expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property); 14534 } else if (lookahead.type === Token.Template && lookahead.head) { 14535 quasi = parseTemplateLiteral(); 14536 expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi); 14537 } else { 14538 break; 14539 } 14540 } 14541 return expr; 14542 } 14543 14544 // ECMA-262 12.4 Postfix Expressions 14545 14546 function parsePostfixExpression() { 14547 var expr, token, startToken = lookahead; 14548 14549 expr = inheritCoverGrammar(parseLeftHandSideExpressionAllowCall); 14550 14551 if (!hasLineTerminator && lookahead.type === Token.Punctuator) { 14552 if (match('++') || match('--')) { 14553 // ECMA-262 11.3.1, 11.3.2 14554 if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) { 14555 tolerateError(Messages.StrictLHSPostfix); 14556 } 14557 14558 if (!isAssignmentTarget) { 14559 tolerateError(Messages.InvalidLHSInAssignment); 14560 } 14561 14562 isAssignmentTarget = isBindingElement = false; 14563 14564 token = lex(); 14565 expr = new WrappingNode(startToken).finishPostfixExpression(token.value, expr); 14566 } 14567 } 14568 14569 return expr; 14570 } 14571 14572 // ECMA-262 12.5 Unary Operators 14573 14574 function parseUnaryExpression() { 14575 var token, expr, startToken; 14576 14577 if (lookahead.type !== Token.Punctuator && lookahead.type !== Token.Keyword) { 14578 expr = parsePostfixExpression(); 14579 } else if (match('++') || match('--')) { 14580 startToken = lookahead; 14581 token = lex(); 14582 expr = inheritCoverGrammar(parseUnaryExpression); 14583 // ECMA-262 11.4.4, 11.4.5 14584 if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) { 14585 tolerateError(Messages.StrictLHSPrefix); 14586 } 14587 14588 if (!isAssignmentTarget) { 14589 tolerateError(Messages.InvalidLHSInAssignment); 14590 } 14591 expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr); 14592 isAssignmentTarget = isBindingElement = false; 14593 } else if (match('+') || match('-') || match('~') || match('!')) { 14594 startToken = lookahead; 14595 token = lex(); 14596 expr = inheritCoverGrammar(parseUnaryExpression); 14597 expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr); 14598 isAssignmentTarget = isBindingElement = false; 14599 } else if (matchKeyword('delete') || matchKeyword('void') || matchKeyword('typeof')) { 14600 startToken = lookahead; 14601 token = lex(); 14602 expr = inheritCoverGrammar(parseUnaryExpression); 14603 expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr); 14604 if (strict && expr.operator === 'delete' && expr.argument.type === Syntax.Identifier) { 14605 tolerateError(Messages.StrictDelete); 14606 } 14607 isAssignmentTarget = isBindingElement = false; 14608 } else { 14609 expr = parsePostfixExpression(); 14610 } 14611 14612 return expr; 14613 } 14614 14615 function binaryPrecedence(token, allowIn) { 14616 var prec = 0; 14617 14618 if (token.type !== Token.Punctuator && token.type !== Token.Keyword) { 14619 return 0; 14620 } 14621 14622 switch (token.value) { 14623 case '||': 14624 prec = 1; 14625 break; 14626 14627 case '&&': 14628 prec = 2; 14629 break; 14630 14631 case '|': 14632 prec = 3; 14633 break; 14634 14635 case '^': 14636 prec = 4; 14637 break; 14638 14639 case '&': 14640 prec = 5; 14641 break; 14642 14643 case '==': 14644 case '!=': 14645 case '===': 14646 case '!==': 14647 prec = 6; 14648 break; 14649 14650 case '<': 14651 case '>': 14652 case '<=': 14653 case '>=': 14654 case 'instanceof': 14655 prec = 7; 14656 break; 14657 14658 case 'in': 14659 prec = allowIn ? 7 : 0; 14660 break; 14661 14662 case '<<': 14663 case '>>': 14664 case '>>>': 14665 prec = 8; 14666 break; 14667 14668 case '+': 14669 case '-': 14670 prec = 9; 14671 break; 14672 14673 case '*': 14674 case '/': 14675 case '%': 14676 prec = 11; 14677 break; 14678 14679 default: 14680 break; 14681 } 14682 14683 return prec; 14684 } 14685 14686 // ECMA-262 12.6 Multiplicative Operators 14687 // ECMA-262 12.7 Additive Operators 14688 // ECMA-262 12.8 Bitwise Shift Operators 14689 // ECMA-262 12.9 Relational Operators 14690 // ECMA-262 12.10 Equality Operators 14691 // ECMA-262 12.11 Binary Bitwise Operators 14692 // ECMA-262 12.12 Binary Logical Operators 14693 14694 function parseBinaryExpression() { 14695 var marker, markers, expr, token, prec, stack, right, operator, left, i; 14696 14697 marker = lookahead; 14698 left = inheritCoverGrammar(parseUnaryExpression); 14699 14700 token = lookahead; 14701 prec = binaryPrecedence(token, state.allowIn); 14702 if (prec === 0) { 14703 return left; 14704 } 14705 isAssignmentTarget = isBindingElement = false; 14706 token.prec = prec; 14707 lex(); 14708 14709 markers = [marker, lookahead]; 14710 right = isolateCoverGrammar(parseUnaryExpression); 14711 14712 stack = [left, token, right]; 14713 14714 while ((prec = binaryPrecedence(lookahead, state.allowIn)) > 0) { 14715 14716 // Reduce: make a binary expression from the three topmost entries. 14717 while ((stack.length > 2) && (prec <= stack[stack.length - 2].prec)) { 14718 right = stack.pop(); 14719 operator = stack.pop().value; 14720 left = stack.pop(); 14721 markers.pop(); 14722 expr = new WrappingNode(markers[markers.length - 1]).finishBinaryExpression(operator, left, right); 14723 stack.push(expr); 14724 } 14725 14726 // Shift. 14727 token = lex(); 14728 token.prec = prec; 14729 stack.push(token); 14730 markers.push(lookahead); 14731 expr = isolateCoverGrammar(parseUnaryExpression); 14732 stack.push(expr); 14733 } 14734 14735 // Final reduce to clean-up the stack. 14736 i = stack.length - 1; 14737 expr = stack[i]; 14738 markers.pop(); 14739 while (i > 1) { 14740 expr = new WrappingNode(markers.pop()).finishBinaryExpression(stack[i - 1].value, stack[i - 2], expr); 14741 i -= 2; 14742 } 14743 14744 return expr; 14745 } 14746 14747 14748 // ECMA-262 12.13 Conditional Operator 14749 14750 function parseConditionalExpression() { 14751 var expr, previousAllowIn, consequent, alternate, startToken; 14752 14753 startToken = lookahead; 14754 14755 expr = inheritCoverGrammar(parseBinaryExpression); 14756 if (match('?')) { 14757 lex(); 14758 previousAllowIn = state.allowIn; 14759 state.allowIn = true; 14760 consequent = isolateCoverGrammar(parseAssignmentExpression); 14761 state.allowIn = previousAllowIn; 14762 expect(':'); 14763 alternate = isolateCoverGrammar(parseAssignmentExpression); 14764 14765 expr = new WrappingNode(startToken).finishConditionalExpression(expr, consequent, alternate); 14766 isAssignmentTarget = isBindingElement = false; 14767 } 14768 14769 return expr; 14770 } 14771 14772 // ECMA-262 14.2 Arrow Function Definitions 14773 14774 function parseConciseBody() { 14775 if (match('{')) { 14776 return parseFunctionSourceElements(); 14777 } 14778 return isolateCoverGrammar(parseAssignmentExpression); 14779 } 14780 14781 function checkPatternParam(options, param) { 14782 var i; 14783 switch (param.type) { 14784 case Syntax.Identifier: 14785 validateParam(options, param, param.name); 14786 break; 14787 case Syntax.RestElement: 14788 checkPatternParam(options, param.argument); 14789 break; 14790 case Syntax.AssignmentPattern: 14791 checkPatternParam(options, param.left); 14792 break; 14793 case Syntax.ArrayPattern: 14794 for (i = 0; i < param.elements.length; i++) { 14795 if (param.elements[i] !== null) { 14796 checkPatternParam(options, param.elements[i]); 14797 } 14798 } 14799 break; 14800 case Syntax.YieldExpression: 14801 break; 14802 default: 14803 assert(param.type === Syntax.ObjectPattern, 'Invalid type'); 14804 for (i = 0; i < param.properties.length; i++) { 14805 checkPatternParam(options, param.properties[i].value); 14806 } 14807 break; 14808 } 14809 } 14810 function reinterpretAsCoverFormalsList(expr) { 14811 var i, len, param, params, defaults, defaultCount, options, token; 14812 14813 defaults = []; 14814 defaultCount = 0; 14815 params = [expr]; 14816 14817 switch (expr.type) { 14818 case Syntax.Identifier: 14819 break; 14820 case PlaceHolders.ArrowParameterPlaceHolder: 14821 params = expr.params; 14822 break; 14823 default: 14824 return null; 14825 } 14826 14827 options = { 14828 paramSet: {} 14829 }; 14830 14831 for (i = 0, len = params.length; i < len; i += 1) { 14832 param = params[i]; 14833 switch (param.type) { 14834 case Syntax.AssignmentPattern: 14835 params[i] = param.left; 14836 if (param.right.type === Syntax.YieldExpression) { 14837 if (param.right.argument) { 14838 throwUnexpectedToken(lookahead); 14839 } 14840 param.right.type = Syntax.Identifier; 14841 param.right.name = 'yield'; 14842 delete param.right.argument; 14843 delete param.right.delegate; 14844 } 14845 defaults.push(param.right); 14846 ++defaultCount; 14847 checkPatternParam(options, param.left); 14848 break; 14849 default: 14850 checkPatternParam(options, param); 14851 params[i] = param; 14852 defaults.push(null); 14853 break; 14854 } 14855 } 14856 14857 if (strict || !state.allowYield) { 14858 for (i = 0, len = params.length; i < len; i += 1) { 14859 param = params[i]; 14860 if (param.type === Syntax.YieldExpression) { 14861 throwUnexpectedToken(lookahead); 14862 } 14863 } 14864 } 14865 14866 if (options.message === Messages.StrictParamDupe) { 14867 token = strict ? options.stricted : options.firstRestricted; 14868 throwUnexpectedToken(token, options.message); 14869 } 14870 14871 if (defaultCount === 0) { 14872 defaults = []; 14873 } 14874 14875 return { 14876 params: params, 14877 defaults: defaults, 14878 stricted: options.stricted, 14879 firstRestricted: options.firstRestricted, 14880 message: options.message 14881 }; 14882 } 14883 14884 function parseArrowFunctionExpression(options, node) { 14885 var previousStrict, previousAllowYield, body; 14886 14887 if (hasLineTerminator) { 14888 tolerateUnexpectedToken(lookahead); 14889 } 14890 expect('=>'); 14891 14892 previousStrict = strict; 14893 previousAllowYield = state.allowYield; 14894 state.allowYield = true; 14895 14896 body = parseConciseBody(); 14897 14898 if (strict && options.firstRestricted) { 14899 throwUnexpectedToken(options.firstRestricted, options.message); 14900 } 14901 if (strict && options.stricted) { 14902 tolerateUnexpectedToken(options.stricted, options.message); 14903 } 14904 14905 strict = previousStrict; 14906 state.allowYield = previousAllowYield; 14907 14908 return node.finishArrowFunctionExpression(options.params, options.defaults, body, body.type !== Syntax.BlockStatement); 14909 } 14910 14911 // ECMA-262 14.4 Yield expression 14912 14913 function parseYieldExpression() { 14914 var argument, expr, delegate, previousAllowYield; 14915 14916 argument = null; 14917 expr = new Node(); 14918 delegate = false; 14919 14920 expectKeyword('yield'); 14921 14922 if (!hasLineTerminator) { 14923 previousAllowYield = state.allowYield; 14924 state.allowYield = false; 14925 delegate = match('*'); 14926 if (delegate) { 14927 lex(); 14928 argument = parseAssignmentExpression(); 14929 } else { 14930 if (!match(';') && !match('}') && !match(')') && lookahead.type !== Token.EOF) { 14931 argument = parseAssignmentExpression(); 14932 } 14933 } 14934 state.allowYield = previousAllowYield; 14935 } 14936 14937 return expr.finishYieldExpression(argument, delegate); 14938 } 14939 14940 // ECMA-262 12.14 Assignment Operators 14941 14942 function parseAssignmentExpression() { 14943 var token, expr, right, list, startToken; 14944 14945 startToken = lookahead; 14946 token = lookahead; 14947 14948 if (!state.allowYield && matchKeyword('yield')) { 14949 return parseYieldExpression(); 14950 } 14951 14952 expr = parseConditionalExpression(); 14953 14954 if (expr.type === PlaceHolders.ArrowParameterPlaceHolder || match('=>')) { 14955 isAssignmentTarget = isBindingElement = false; 14956 list = reinterpretAsCoverFormalsList(expr); 14957 14958 if (list) { 14959 firstCoverInitializedNameError = null; 14960 return parseArrowFunctionExpression(list, new WrappingNode(startToken)); 14961 } 14962 14963 return expr; 14964 } 14965 14966 if (matchAssign()) { 14967 if (!isAssignmentTarget) { 14968 tolerateError(Messages.InvalidLHSInAssignment); 14969 } 14970 14971 // ECMA-262 12.1.1 14972 if (strict && expr.type === Syntax.Identifier) { 14973 if (isRestrictedWord(expr.name)) { 14974 tolerateUnexpectedToken(token, Messages.StrictLHSAssignment); 14975 } 14976 if (isStrictModeReservedWord(expr.name)) { 14977 tolerateUnexpectedToken(token, Messages.StrictReservedWord); 14978 } 14979 } 14980 14981 if (!match('=')) { 14982 isAssignmentTarget = isBindingElement = false; 14983 } else { 14984 reinterpretExpressionAsPattern(expr); 14985 } 14986 14987 token = lex(); 14988 right = isolateCoverGrammar(parseAssignmentExpression); 14989 expr = new WrappingNode(startToken).finishAssignmentExpression(token.value, expr, right); 14990 firstCoverInitializedNameError = null; 14991 } 14992 14993 return expr; 14994 } 14995 14996 // ECMA-262 12.15 Comma Operator 14997 14998 function parseExpression() { 14999 var expr, startToken = lookahead, expressions; 15000 15001 expr = isolateCoverGrammar(parseAssignmentExpression); 15002 15003 if (match(',')) { 15004 expressions = [expr]; 15005 15006 while (startIndex < length) { 15007 if (!match(',')) { 15008 break; 15009 } 15010 lex(); 15011 expressions.push(isolateCoverGrammar(parseAssignmentExpression)); 15012 } 15013 15014 expr = new WrappingNode(startToken).finishSequenceExpression(expressions); 15015 } 15016 15017 return expr; 15018 } 15019 15020 // ECMA-262 13.2 Block 15021 15022 function parseStatementListItem() { 15023 if (lookahead.type === Token.Keyword) { 15024 switch (lookahead.value) { 15025 case 'export': 15026 if (state.sourceType !== 'module') { 15027 tolerateUnexpectedToken(lookahead, Messages.IllegalExportDeclaration); 15028 } 15029 return parseExportDeclaration(); 15030 case 'import': 15031 if (state.sourceType !== 'module') { 15032 tolerateUnexpectedToken(lookahead, Messages.IllegalImportDeclaration); 15033 } 15034 return parseImportDeclaration(); 15035 case 'const': 15036 return parseLexicalDeclaration({inFor: false}); 15037 case 'function': 15038 return parseFunctionDeclaration(new Node()); 15039 case 'class': 15040 return parseClassDeclaration(); 15041 } 15042 } 15043 15044 if (matchKeyword('let') && isLexicalDeclaration()) { 15045 return parseLexicalDeclaration({inFor: false}); 15046 } 15047 15048 return parseStatement(); 15049 } 15050 15051 function parseStatementList() { 15052 var list = []; 15053 while (startIndex < length) { 15054 if (match('}')) { 15055 break; 15056 } 15057 list.push(parseStatementListItem()); 15058 } 15059 15060 return list; 15061 } 15062 15063 function parseBlock() { 15064 var block, node = new Node(); 15065 15066 expect('{'); 15067 15068 block = parseStatementList(); 15069 15070 expect('}'); 15071 15072 return node.finishBlockStatement(block); 15073 } 15074 15075 // ECMA-262 13.3.2 Variable Statement 15076 15077 function parseVariableIdentifier(kind) { 15078 var token, node = new Node(); 15079 15080 token = lex(); 15081 15082 if (token.type === Token.Keyword && token.value === 'yield') { 15083 if (strict) { 15084 tolerateUnexpectedToken(token, Messages.StrictReservedWord); 15085 } if (!state.allowYield) { 15086 throwUnexpectedToken(token); 15087 } 15088 } else if (token.type !== Token.Identifier) { 15089 if (strict && token.type === Token.Keyword && isStrictModeReservedWord(token.value)) { 15090 tolerateUnexpectedToken(token, Messages.StrictReservedWord); 15091 } else { 15092 if (strict || token.value !== 'let' || kind !== 'var') { 15093 throwUnexpectedToken(token); 15094 } 15095 } 15096 } else if (state.sourceType === 'module' && token.type === Token.Identifier && token.value === 'await') { 15097 tolerateUnexpectedToken(token); 15098 } 15099 15100 return node.finishIdentifier(token.value); 15101 } 15102 15103 function parseVariableDeclaration(options) { 15104 var init = null, id, node = new Node(), params = []; 15105 15106 id = parsePattern(params, 'var'); 15107 15108 // ECMA-262 12.2.1 15109 if (strict && isRestrictedWord(id.name)) { 15110 tolerateError(Messages.StrictVarName); 15111 } 15112 15113 if (match('=')) { 15114 lex(); 15115 init = isolateCoverGrammar(parseAssignmentExpression); 15116 } else if (id.type !== Syntax.Identifier && !options.inFor) { 15117 expect('='); 15118 } 15119 15120 return node.finishVariableDeclarator(id, init); 15121 } 15122 15123 function parseVariableDeclarationList(options) { 15124 var opt, list; 15125 15126 opt = { inFor: options.inFor }; 15127 list = [parseVariableDeclaration(opt)]; 15128 15129 while (match(',')) { 15130 lex(); 15131 list.push(parseVariableDeclaration(opt)); 15132 } 15133 15134 return list; 15135 } 15136 15137 function parseVariableStatement(node) { 15138 var declarations; 15139 15140 expectKeyword('var'); 15141 15142 declarations = parseVariableDeclarationList({ inFor: false }); 15143 15144 consumeSemicolon(); 15145 15146 return node.finishVariableDeclaration(declarations); 15147 } 15148 15149 // ECMA-262 13.3.1 Let and Const Declarations 15150 15151 function parseLexicalBinding(kind, options) { 15152 var init = null, id, node = new Node(), params = []; 15153 15154 id = parsePattern(params, kind); 15155 15156 // ECMA-262 12.2.1 15157 if (strict && id.type === Syntax.Identifier && isRestrictedWord(id.name)) { 15158 tolerateError(Messages.StrictVarName); 15159 } 15160 15161 if (kind === 'const') { 15162 if (!matchKeyword('in') && !matchContextualKeyword('of')) { 15163 expect('='); 15164 init = isolateCoverGrammar(parseAssignmentExpression); 15165 } 15166 } else if ((!options.inFor && id.type !== Syntax.Identifier) || match('=')) { 15167 expect('='); 15168 init = isolateCoverGrammar(parseAssignmentExpression); 15169 } 15170 15171 return node.finishVariableDeclarator(id, init); 15172 } 15173 15174 function parseBindingList(kind, options) { 15175 var list = [parseLexicalBinding(kind, options)]; 15176 15177 while (match(',')) { 15178 lex(); 15179 list.push(parseLexicalBinding(kind, options)); 15180 } 15181 15182 return list; 15183 } 15184 15185 15186 function tokenizerState() { 15187 return { 15188 index: index, 15189 lineNumber: lineNumber, 15190 lineStart: lineStart, 15191 hasLineTerminator: hasLineTerminator, 15192 lastIndex: lastIndex, 15193 lastLineNumber: lastLineNumber, 15194 lastLineStart: lastLineStart, 15195 startIndex: startIndex, 15196 startLineNumber: startLineNumber, 15197 startLineStart: startLineStart, 15198 lookahead: lookahead, 15199 tokenCount: extra.tokens ? extra.tokens.length : 0 15200 }; 15201 } 15202 15203 function resetTokenizerState(ts) { 15204 index = ts.index; 15205 lineNumber = ts.lineNumber; 15206 lineStart = ts.lineStart; 15207 hasLineTerminator = ts.hasLineTerminator; 15208 lastIndex = ts.lastIndex; 15209 lastLineNumber = ts.lastLineNumber; 15210 lastLineStart = ts.lastLineStart; 15211 startIndex = ts.startIndex; 15212 startLineNumber = ts.startLineNumber; 15213 startLineStart = ts.startLineStart; 15214 lookahead = ts.lookahead; 15215 if (extra.tokens) { 15216 extra.tokens.splice(ts.tokenCount, extra.tokens.length); 15217 } 15218 } 15219 15220 function isLexicalDeclaration() { 15221 var lexical, ts; 15222 15223 ts = tokenizerState(); 15224 15225 lex(); 15226 lexical = (lookahead.type === Token.Identifier) || match('[') || match('{') || 15227 matchKeyword('let') || matchKeyword('yield'); 15228 15229 resetTokenizerState(ts); 15230 15231 return lexical; 15232 } 15233 15234 function parseLexicalDeclaration(options) { 15235 var kind, declarations, node = new Node(); 15236 15237 kind = lex().value; 15238 assert(kind === 'let' || kind === 'const', 'Lexical declaration must be either let or const'); 15239 15240 declarations = parseBindingList(kind, options); 15241 15242 consumeSemicolon(); 15243 15244 return node.finishLexicalDeclaration(declarations, kind); 15245 } 15246 15247 function parseRestElement(params) { 15248 var param, node = new Node(); 15249 15250 lex(); 15251 15252 if (match('{')) { 15253 throwError(Messages.ObjectPatternAsRestParameter); 15254 } 15255 15256 params.push(lookahead); 15257 15258 param = parseVariableIdentifier(); 15259 15260 if (match('=')) { 15261 throwError(Messages.DefaultRestParameter); 15262 } 15263 15264 if (!match(')')) { 15265 throwError(Messages.ParameterAfterRestParameter); 15266 } 15267 15268 return node.finishRestElement(param); 15269 } 15270 15271 // ECMA-262 13.4 Empty Statement 15272 15273 function parseEmptyStatement(node) { 15274 expect(';'); 15275 return node.finishEmptyStatement(); 15276 } 15277 15278 // ECMA-262 12.4 Expression Statement 15279 15280 function parseExpressionStatement(node) { 15281 var expr = parseExpression(); 15282 consumeSemicolon(); 15283 return node.finishExpressionStatement(expr); 15284 } 15285 15286 // ECMA-262 13.6 If statement 15287 15288 function parseIfStatement(node) { 15289 var test, consequent, alternate; 15290 15291 expectKeyword('if'); 15292 15293 expect('('); 15294 15295 test = parseExpression(); 15296 15297 expect(')'); 15298 15299 consequent = parseStatement(); 15300 15301 if (matchKeyword('else')) { 15302 lex(); 15303 alternate = parseStatement(); 15304 } else { 15305 alternate = null; 15306 } 15307 15308 return node.finishIfStatement(test, consequent, alternate); 15309 } 15310 15311 // ECMA-262 13.7 Iteration Statements 15312 15313 function parseDoWhileStatement(node) { 15314 var body, test, oldInIteration; 15315 15316 expectKeyword('do'); 15317 15318 oldInIteration = state.inIteration; 15319 state.inIteration = true; 15320 15321 body = parseStatement(); 15322 15323 state.inIteration = oldInIteration; 15324 15325 expectKeyword('while'); 15326 15327 expect('('); 15328 15329 test = parseExpression(); 15330 15331 expect(')'); 15332 15333 if (match(';')) { 15334 lex(); 15335 } 15336 15337 return node.finishDoWhileStatement(body, test); 15338 } 15339 15340 function parseWhileStatement(node) { 15341 var test, body, oldInIteration; 15342 15343 expectKeyword('while'); 15344 15345 expect('('); 15346 15347 test = parseExpression(); 15348 15349 expect(')'); 15350 15351 oldInIteration = state.inIteration; 15352 state.inIteration = true; 15353 15354 body = parseStatement(); 15355 15356 state.inIteration = oldInIteration; 15357 15358 return node.finishWhileStatement(test, body); 15359 } 15360 15361 function parseForStatement(node) { 15362 var init, forIn, initSeq, initStartToken, test, update, left, right, kind, declarations, 15363 body, oldInIteration, previousAllowIn = state.allowIn; 15364 15365 init = test = update = null; 15366 forIn = true; 15367 15368 expectKeyword('for'); 15369 15370 expect('('); 15371 15372 if (match(';')) { 15373 lex(); 15374 } else { 15375 if (matchKeyword('var')) { 15376 init = new Node(); 15377 lex(); 15378 15379 state.allowIn = false; 15380 declarations = parseVariableDeclarationList({ inFor: true }); 15381 state.allowIn = previousAllowIn; 15382 15383 if (declarations.length === 1 && matchKeyword('in')) { 15384 init = init.finishVariableDeclaration(declarations); 15385 lex(); 15386 left = init; 15387 right = parseExpression(); 15388 init = null; 15389 } else if (declarations.length === 1 && declarations[0].init === null && matchContextualKeyword('of')) { 15390 init = init.finishVariableDeclaration(declarations); 15391 lex(); 15392 left = init; 15393 right = parseAssignmentExpression(); 15394 init = null; 15395 forIn = false; 15396 } else { 15397 init = init.finishVariableDeclaration(declarations); 15398 expect(';'); 15399 } 15400 } else if (matchKeyword('const') || matchKeyword('let')) { 15401 init = new Node(); 15402 kind = lex().value; 15403 15404 if (!strict && lookahead.value === 'in') { 15405 init = init.finishIdentifier(kind); 15406 lex(); 15407 left = init; 15408 right = parseExpression(); 15409 init = null; 15410 } else { 15411 state.allowIn = false; 15412 declarations = parseBindingList(kind, {inFor: true}); 15413 state.allowIn = previousAllowIn; 15414 15415 if (declarations.length === 1 && declarations[0].init === null && matchKeyword('in')) { 15416 init = init.finishLexicalDeclaration(declarations, kind); 15417 lex(); 15418 left = init; 15419 right = parseExpression(); 15420 init = null; 15421 } else if (declarations.length === 1 && declarations[0].init === null && matchContextualKeyword('of')) { 15422 init = init.finishLexicalDeclaration(declarations, kind); 15423 lex(); 15424 left = init; 15425 right = parseAssignmentExpression(); 15426 init = null; 15427 forIn = false; 15428 } else { 15429 consumeSemicolon(); 15430 init = init.finishLexicalDeclaration(declarations, kind); 15431 } 15432 } 15433 } else { 15434 initStartToken = lookahead; 15435 state.allowIn = false; 15436 init = inheritCoverGrammar(parseAssignmentExpression); 15437 state.allowIn = previousAllowIn; 15438 15439 if (matchKeyword('in')) { 15440 if (!isAssignmentTarget) { 15441 tolerateError(Messages.InvalidLHSInForIn); 15442 } 15443 15444 lex(); 15445 reinterpretExpressionAsPattern(init); 15446 left = init; 15447 right = parseExpression(); 15448 init = null; 15449 } else if (matchContextualKeyword('of')) { 15450 if (!isAssignmentTarget) { 15451 tolerateError(Messages.InvalidLHSInForLoop); 15452 } 15453 15454 lex(); 15455 reinterpretExpressionAsPattern(init); 15456 left = init; 15457 right = parseAssignmentExpression(); 15458 init = null; 15459 forIn = false; 15460 } else { 15461 if (match(',')) { 15462 initSeq = [init]; 15463 while (match(',')) { 15464 lex(); 15465 initSeq.push(isolateCoverGrammar(parseAssignmentExpression)); 15466 } 15467 init = new WrappingNode(initStartToken).finishSequenceExpression(initSeq); 15468 } 15469 expect(';'); 15470 } 15471 } 15472 } 15473 15474 if (typeof left === 'undefined') { 15475 15476 if (!match(';')) { 15477 test = parseExpression(); 15478 } 15479 expect(';'); 15480 15481 if (!match(')')) { 15482 update = parseExpression(); 15483 } 15484 } 15485 15486 expect(')'); 15487 15488 oldInIteration = state.inIteration; 15489 state.inIteration = true; 15490 15491 body = isolateCoverGrammar(parseStatement); 15492 15493 state.inIteration = oldInIteration; 15494 15495 return (typeof left === 'undefined') ? 15496 node.finishForStatement(init, test, update, body) : 15497 forIn ? node.finishForInStatement(left, right, body) : 15498 node.finishForOfStatement(left, right, body); 15499 } 15500 15501 // ECMA-262 13.8 The continue statement 15502 15503 function parseContinueStatement(node) { 15504 var label = null, key; 15505 15506 expectKeyword('continue'); 15507 15508 // Optimize the most common form: 'continue;'. 15509 if (source.charCodeAt(startIndex) === 0x3B) { 15510 lex(); 15511 15512 if (!state.inIteration) { 15513 throwError(Messages.IllegalContinue); 15514 } 15515 15516 return node.finishContinueStatement(null); 15517 } 15518 15519 if (hasLineTerminator) { 15520 if (!state.inIteration) { 15521 throwError(Messages.IllegalContinue); 15522 } 15523 15524 return node.finishContinueStatement(null); 15525 } 15526 15527 if (lookahead.type === Token.Identifier) { 15528 label = parseVariableIdentifier(); 15529 15530 key = '$' + label.name; 15531 if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) { 15532 throwError(Messages.UnknownLabel, label.name); 15533 } 15534 } 15535 15536 consumeSemicolon(); 15537 15538 if (label === null && !state.inIteration) { 15539 throwError(Messages.IllegalContinue); 15540 } 15541 15542 return node.finishContinueStatement(label); 15543 } 15544 15545 // ECMA-262 13.9 The break statement 15546 15547 function parseBreakStatement(node) { 15548 var label = null, key; 15549 15550 expectKeyword('break'); 15551 15552 // Catch the very common case first: immediately a semicolon (U+003B). 15553 if (source.charCodeAt(lastIndex) === 0x3B) { 15554 lex(); 15555 15556 if (!(state.inIteration || state.inSwitch)) { 15557 throwError(Messages.IllegalBreak); 15558 } 15559 15560 return node.finishBreakStatement(null); 15561 } 15562 15563 if (hasLineTerminator) { 15564 if (!(state.inIteration || state.inSwitch)) { 15565 throwError(Messages.IllegalBreak); 15566 } 15567 } else if (lookahead.type === Token.Identifier) { 15568 label = parseVariableIdentifier(); 15569 15570 key = '$' + label.name; 15571 if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) { 15572 throwError(Messages.UnknownLabel, label.name); 15573 } 15574 } 15575 15576 consumeSemicolon(); 15577 15578 if (label === null && !(state.inIteration || state.inSwitch)) { 15579 throwError(Messages.IllegalBreak); 15580 } 15581 15582 return node.finishBreakStatement(label); 15583 } 15584 15585 // ECMA-262 13.10 The return statement 15586 15587 function parseReturnStatement(node) { 15588 var argument = null; 15589 15590 expectKeyword('return'); 15591 15592 if (!state.inFunctionBody) { 15593 tolerateError(Messages.IllegalReturn); 15594 } 15595 15596 // 'return' followed by a space and an identifier is very common. 15597 if (source.charCodeAt(lastIndex) === 0x20) { 15598 if (isIdentifierStart(source.charCodeAt(lastIndex + 1))) { 15599 argument = parseExpression(); 15600 consumeSemicolon(); 15601 return node.finishReturnStatement(argument); 15602 } 15603 } 15604 15605 if (hasLineTerminator) { 15606 // HACK 15607 return node.finishReturnStatement(null); 15608 } 15609 15610 if (!match(';')) { 15611 if (!match('}') && lookahead.type !== Token.EOF) { 15612 argument = parseExpression(); 15613 } 15614 } 15615 15616 consumeSemicolon(); 15617 15618 return node.finishReturnStatement(argument); 15619 } 15620 15621 // ECMA-262 13.11 The with statement 15622 15623 function parseWithStatement(node) { 15624 var object, body; 15625 15626 if (strict) { 15627 tolerateError(Messages.StrictModeWith); 15628 } 15629 15630 expectKeyword('with'); 15631 15632 expect('('); 15633 15634 object = parseExpression(); 15635 15636 expect(')'); 15637 15638 body = parseStatement(); 15639 15640 return node.finishWithStatement(object, body); 15641 } 15642 15643 // ECMA-262 13.12 The switch statement 15644 15645 function parseSwitchCase() { 15646 var test, consequent = [], statement, node = new Node(); 15647 15648 if (matchKeyword('default')) { 15649 lex(); 15650 test = null; 15651 } else { 15652 expectKeyword('case'); 15653 test = parseExpression(); 15654 } 15655 expect(':'); 15656 15657 while (startIndex < length) { 15658 if (match('}') || matchKeyword('default') || matchKeyword('case')) { 15659 break; 15660 } 15661 statement = parseStatementListItem(); 15662 consequent.push(statement); 15663 } 15664 15665 return node.finishSwitchCase(test, consequent); 15666 } 15667 15668 function parseSwitchStatement(node) { 15669 var discriminant, cases, clause, oldInSwitch, defaultFound; 15670 15671 expectKeyword('switch'); 15672 15673 expect('('); 15674 15675 discriminant = parseExpression(); 15676 15677 expect(')'); 15678 15679 expect('{'); 15680 15681 cases = []; 15682 15683 if (match('}')) { 15684 lex(); 15685 return node.finishSwitchStatement(discriminant, cases); 15686 } 15687 15688 oldInSwitch = state.inSwitch; 15689 state.inSwitch = true; 15690 defaultFound = false; 15691 15692 while (startIndex < length) { 15693 if (match('}')) { 15694 break; 15695 } 15696 clause = parseSwitchCase(); 15697 if (clause.test === null) { 15698 if (defaultFound) { 15699 throwError(Messages.MultipleDefaultsInSwitch); 15700 } 15701 defaultFound = true; 15702 } 15703 cases.push(clause); 15704 } 15705 15706 state.inSwitch = oldInSwitch; 15707 15708 expect('}'); 15709 15710 return node.finishSwitchStatement(discriminant, cases); 15711 } 15712 15713 // ECMA-262 13.14 The throw statement 15714 15715 function parseThrowStatement(node) { 15716 var argument; 15717 15718 expectKeyword('throw'); 15719 15720 if (hasLineTerminator) { 15721 throwError(Messages.NewlineAfterThrow); 15722 } 15723 15724 argument = parseExpression(); 15725 15726 consumeSemicolon(); 15727 15728 return node.finishThrowStatement(argument); 15729 } 15730 15731 // ECMA-262 13.15 The try statement 15732 15733 function parseCatchClause() { 15734 var param, params = [], paramMap = {}, key, i, body, node = new Node(); 15735 15736 expectKeyword('catch'); 15737 15738 expect('('); 15739 if (match(')')) { 15740 throwUnexpectedToken(lookahead); 15741 } 15742 15743 param = parsePattern(params); 15744 for (i = 0; i < params.length; i++) { 15745 key = '$' + params[i].value; 15746 if (Object.prototype.hasOwnProperty.call(paramMap, key)) { 15747 tolerateError(Messages.DuplicateBinding, params[i].value); 15748 } 15749 paramMap[key] = true; 15750 } 15751 15752 // ECMA-262 12.14.1 15753 if (strict && isRestrictedWord(param.name)) { 15754 tolerateError(Messages.StrictCatchVariable); 15755 } 15756 15757 expect(')'); 15758 body = parseBlock(); 15759 return node.finishCatchClause(param, body); 15760 } 15761 15762 function parseTryStatement(node) { 15763 var block, handler = null, finalizer = null; 15764 15765 expectKeyword('try'); 15766 15767 block = parseBlock(); 15768 15769 if (matchKeyword('catch')) { 15770 handler = parseCatchClause(); 15771 } 15772 15773 if (matchKeyword('finally')) { 15774 lex(); 15775 finalizer = parseBlock(); 15776 } 15777 15778 if (!handler && !finalizer) { 15779 throwError(Messages.NoCatchOrFinally); 15780 } 15781 15782 return node.finishTryStatement(block, handler, finalizer); 15783 } 15784 15785 // ECMA-262 13.16 The debugger statement 15786 15787 function parseDebuggerStatement(node) { 15788 expectKeyword('debugger'); 15789 15790 consumeSemicolon(); 15791 15792 return node.finishDebuggerStatement(); 15793 } 15794 15795 // 13 Statements 15796 15797 function parseStatement() { 15798 var type = lookahead.type, 15799 expr, 15800 labeledBody, 15801 key, 15802 node; 15803 15804 if (type === Token.EOF) { 15805 throwUnexpectedToken(lookahead); 15806 } 15807 15808 if (type === Token.Punctuator && lookahead.value === '{') { 15809 return parseBlock(); 15810 } 15811 isAssignmentTarget = isBindingElement = true; 15812 node = new Node(); 15813 15814 if (type === Token.Punctuator) { 15815 switch (lookahead.value) { 15816 case ';': 15817 return parseEmptyStatement(node); 15818 case '(': 15819 return parseExpressionStatement(node); 15820 default: 15821 break; 15822 } 15823 } else if (type === Token.Keyword) { 15824 switch (lookahead.value) { 15825 case 'break': 15826 return parseBreakStatement(node); 15827 case 'continue': 15828 return parseContinueStatement(node); 15829 case 'debugger': 15830 return parseDebuggerStatement(node); 15831 case 'do': 15832 return parseDoWhileStatement(node); 15833 case 'for': 15834 return parseForStatement(node); 15835 case 'function': 15836 return parseFunctionDeclaration(node); 15837 case 'if': 15838 return parseIfStatement(node); 15839 case 'return': 15840 return parseReturnStatement(node); 15841 case 'switch': 15842 return parseSwitchStatement(node); 15843 case 'throw': 15844 return parseThrowStatement(node); 15845 case 'try': 15846 return parseTryStatement(node); 15847 case 'var': 15848 return parseVariableStatement(node); 15849 case 'while': 15850 return parseWhileStatement(node); 15851 case 'with': 15852 return parseWithStatement(node); 15853 default: 15854 break; 15855 } 15856 } 15857 15858 expr = parseExpression(); 15859 15860 // ECMA-262 12.12 Labelled Statements 15861 if ((expr.type === Syntax.Identifier) && match(':')) { 15862 lex(); 15863 15864 key = '$' + expr.name; 15865 if (Object.prototype.hasOwnProperty.call(state.labelSet, key)) { 15866 throwError(Messages.Redeclaration, 'Label', expr.name); 15867 } 15868 15869 state.labelSet[key] = true; 15870 labeledBody = parseStatement(); 15871 delete state.labelSet[key]; 15872 return node.finishLabeledStatement(expr, labeledBody); 15873 } 15874 15875 consumeSemicolon(); 15876 15877 return node.finishExpressionStatement(expr); 15878 } 15879 15880 // ECMA-262 14.1 Function Definition 15881 15882 function parseFunctionSourceElements() { 15883 var statement, body = [], token, directive, firstRestricted, 15884 oldLabelSet, oldInIteration, oldInSwitch, oldInFunctionBody, oldParenthesisCount, 15885 node = new Node(); 15886 15887 expect('{'); 15888 15889 while (startIndex < length) { 15890 if (lookahead.type !== Token.StringLiteral) { 15891 break; 15892 } 15893 token = lookahead; 15894 15895 statement = parseStatementListItem(); 15896 body.push(statement); 15897 if (statement.expression.type !== Syntax.Literal) { 15898 // this is not directive 15899 break; 15900 } 15901 directive = source.slice(token.start + 1, token.end - 1); 15902 if (directive === 'use strict') { 15903 strict = true; 15904 if (firstRestricted) { 15905 tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral); 15906 } 15907 } else { 15908 if (!firstRestricted && token.octal) { 15909 firstRestricted = token; 15910 } 15911 } 15912 } 15913 15914 oldLabelSet = state.labelSet; 15915 oldInIteration = state.inIteration; 15916 oldInSwitch = state.inSwitch; 15917 oldInFunctionBody = state.inFunctionBody; 15918 oldParenthesisCount = state.parenthesizedCount; 15919 15920 state.labelSet = {}; 15921 state.inIteration = false; 15922 state.inSwitch = false; 15923 state.inFunctionBody = true; 15924 state.parenthesizedCount = 0; 15925 15926 while (startIndex < length) { 15927 if (match('}')) { 15928 break; 15929 } 15930 body.push(parseStatementListItem()); 15931 } 15932 15933 expect('}'); 15934 15935 state.labelSet = oldLabelSet; 15936 state.inIteration = oldInIteration; 15937 state.inSwitch = oldInSwitch; 15938 state.inFunctionBody = oldInFunctionBody; 15939 state.parenthesizedCount = oldParenthesisCount; 15940 15941 return node.finishBlockStatement(body); 15942 } 15943 15944 function validateParam(options, param, name) { 15945 var key = '$' + name; 15946 if (strict) { 15947 if (isRestrictedWord(name)) { 15948 options.stricted = param; 15949 options.message = Messages.StrictParamName; 15950 } 15951 if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) { 15952 options.stricted = param; 15953 options.message = Messages.StrictParamDupe; 15954 } 15955 } else if (!options.firstRestricted) { 15956 if (isRestrictedWord(name)) { 15957 options.firstRestricted = param; 15958 options.message = Messages.StrictParamName; 15959 } else if (isStrictModeReservedWord(name)) { 15960 options.firstRestricted = param; 15961 options.message = Messages.StrictReservedWord; 15962 } else if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) { 15963 options.stricted = param; 15964 options.message = Messages.StrictParamDupe; 15965 } 15966 } 15967 options.paramSet[key] = true; 15968 } 15969 15970 function parseParam(options) { 15971 var token, param, params = [], i, def; 15972 15973 token = lookahead; 15974 if (token.value === '...') { 15975 param = parseRestElement(params); 15976 validateParam(options, param.argument, param.argument.name); 15977 options.params.push(param); 15978 options.defaults.push(null); 15979 return false; 15980 } 15981 15982 param = parsePatternWithDefault(params); 15983 for (i = 0; i < params.length; i++) { 15984 validateParam(options, params[i], params[i].value); 15985 } 15986 15987 if (param.type === Syntax.AssignmentPattern) { 15988 def = param.right; 15989 param = param.left; 15990 ++options.defaultCount; 15991 } 15992 15993 options.params.push(param); 15994 options.defaults.push(def); 15995 15996 return !match(')'); 15997 } 15998 15999 function parseParams(firstRestricted) { 16000 var options; 16001 16002 options = { 16003 params: [], 16004 defaultCount: 0, 16005 defaults: [], 16006 firstRestricted: firstRestricted 16007 }; 16008 16009 expect('('); 16010 16011 if (!match(')')) { 16012 options.paramSet = {}; 16013 while (startIndex < length) { 16014 if (!parseParam(options)) { 16015 break; 16016 } 16017 expect(','); 16018 } 16019 } 16020 16021 expect(')'); 16022 16023 if (options.defaultCount === 0) { 16024 options.defaults = []; 16025 } 16026 16027 return { 16028 params: options.params, 16029 defaults: options.defaults, 16030 stricted: options.stricted, 16031 firstRestricted: options.firstRestricted, 16032 message: options.message 16033 }; 16034 } 16035 16036 function parseFunctionDeclaration(node, identifierIsOptional) { 16037 var id = null, params = [], defaults = [], body, token, stricted, tmp, firstRestricted, message, previousStrict, 16038 isGenerator, previousAllowYield; 16039 16040 previousAllowYield = state.allowYield; 16041 16042 expectKeyword('function'); 16043 16044 isGenerator = match('*'); 16045 if (isGenerator) { 16046 lex(); 16047 } 16048 16049 if (!identifierIsOptional || !match('(')) { 16050 token = lookahead; 16051 id = parseVariableIdentifier(); 16052 if (strict) { 16053 if (isRestrictedWord(token.value)) { 16054 tolerateUnexpectedToken(token, Messages.StrictFunctionName); 16055 } 16056 } else { 16057 if (isRestrictedWord(token.value)) { 16058 firstRestricted = token; 16059 message = Messages.StrictFunctionName; 16060 } else if (isStrictModeReservedWord(token.value)) { 16061 firstRestricted = token; 16062 message = Messages.StrictReservedWord; 16063 } 16064 } 16065 } 16066 16067 state.allowYield = !isGenerator; 16068 tmp = parseParams(firstRestricted); 16069 params = tmp.params; 16070 defaults = tmp.defaults; 16071 stricted = tmp.stricted; 16072 firstRestricted = tmp.firstRestricted; 16073 if (tmp.message) { 16074 message = tmp.message; 16075 } 16076 16077 16078 previousStrict = strict; 16079 body = parseFunctionSourceElements(); 16080 if (strict && firstRestricted) { 16081 throwUnexpectedToken(firstRestricted, message); 16082 } 16083 if (strict && stricted) { 16084 tolerateUnexpectedToken(stricted, message); 16085 } 16086 16087 strict = previousStrict; 16088 state.allowYield = previousAllowYield; 16089 16090 return node.finishFunctionDeclaration(id, params, defaults, body, isGenerator); 16091 } 16092 16093 function parseFunctionExpression() { 16094 var token, id = null, stricted, firstRestricted, message, tmp, 16095 params = [], defaults = [], body, previousStrict, node = new Node(), 16096 isGenerator, previousAllowYield; 16097 16098 previousAllowYield = state.allowYield; 16099 16100 expectKeyword('function'); 16101 16102 isGenerator = match('*'); 16103 if (isGenerator) { 16104 lex(); 16105 } 16106 16107 state.allowYield = !isGenerator; 16108 if (!match('(')) { 16109 token = lookahead; 16110 id = (!strict && !isGenerator && matchKeyword('yield')) ? parseNonComputedProperty() : parseVariableIdentifier(); 16111 if (strict) { 16112 if (isRestrictedWord(token.value)) { 16113 tolerateUnexpectedToken(token, Messages.StrictFunctionName); 16114 } 16115 } else { 16116 if (isRestrictedWord(token.value)) { 16117 firstRestricted = token; 16118 message = Messages.StrictFunctionName; 16119 } else if (isStrictModeReservedWord(token.value)) { 16120 firstRestricted = token; 16121 message = Messages.StrictReservedWord; 16122 } 16123 } 16124 } 16125 16126 tmp = parseParams(firstRestricted); 16127 params = tmp.params; 16128 defaults = tmp.defaults; 16129 stricted = tmp.stricted; 16130 firstRestricted = tmp.firstRestricted; 16131 if (tmp.message) { 16132 message = tmp.message; 16133 } 16134 16135 previousStrict = strict; 16136 body = parseFunctionSourceElements(); 16137 if (strict && firstRestricted) { 16138 throwUnexpectedToken(firstRestricted, message); 16139 } 16140 if (strict && stricted) { 16141 tolerateUnexpectedToken(stricted, message); 16142 } 16143 strict = previousStrict; 16144 state.allowYield = previousAllowYield; 16145 16146 return node.finishFunctionExpression(id, params, defaults, body, isGenerator); 16147 } 16148 16149 // ECMA-262 14.5 Class Definitions 16150 16151 function parseClassBody() { 16152 var classBody, token, isStatic, hasConstructor = false, body, method, computed, key; 16153 16154 classBody = new Node(); 16155 16156 expect('{'); 16157 body = []; 16158 while (!match('}')) { 16159 if (match(';')) { 16160 lex(); 16161 } else { 16162 method = new Node(); 16163 token = lookahead; 16164 isStatic = false; 16165 computed = match('['); 16166 if (match('*')) { 16167 lex(); 16168 } else { 16169 key = parseObjectPropertyKey(); 16170 if (key.name === 'static' && (lookaheadPropertyName() || match('*'))) { 16171 token = lookahead; 16172 isStatic = true; 16173 computed = match('['); 16174 if (match('*')) { 16175 lex(); 16176 } else { 16177 key = parseObjectPropertyKey(); 16178 } 16179 } 16180 } 16181 method = tryParseMethodDefinition(token, key, computed, method); 16182 if (method) { 16183 method['static'] = isStatic; // jscs:ignore requireDotNotation 16184 if (method.kind === 'init') { 16185 method.kind = 'method'; 16186 } 16187 if (!isStatic) { 16188 if (!method.computed && (method.key.name || method.key.value.toString()) === 'constructor') { 16189 if (method.kind !== 'method' || !method.method || method.value.generator) { 16190 throwUnexpectedToken(token, Messages.ConstructorSpecialMethod); 16191 } 16192 if (hasConstructor) { 16193 throwUnexpectedToken(token, Messages.DuplicateConstructor); 16194 } else { 16195 hasConstructor = true; 16196 } 16197 method.kind = 'constructor'; 16198 } 16199 } else { 16200 if (!method.computed && (method.key.name || method.key.value.toString()) === 'prototype') { 16201 throwUnexpectedToken(token, Messages.StaticPrototype); 16202 } 16203 } 16204 method.type = Syntax.MethodDefinition; 16205 delete method.method; 16206 delete method.shorthand; 16207 body.push(method); 16208 } else { 16209 throwUnexpectedToken(lookahead); 16210 } 16211 } 16212 } 16213 lex(); 16214 return classBody.finishClassBody(body); 16215 } 16216 16217 function parseClassDeclaration(identifierIsOptional) { 16218 var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict; 16219 strict = true; 16220 16221 expectKeyword('class'); 16222 16223 if (!identifierIsOptional || lookahead.type === Token.Identifier) { 16224 id = parseVariableIdentifier(); 16225 } 16226 16227 if (matchKeyword('extends')) { 16228 lex(); 16229 superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall); 16230 } 16231 classBody = parseClassBody(); 16232 strict = previousStrict; 16233 16234 return classNode.finishClassDeclaration(id, superClass, classBody); 16235 } 16236 16237 function parseClassExpression() { 16238 var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict; 16239 strict = true; 16240 16241 expectKeyword('class'); 16242 16243 if (lookahead.type === Token.Identifier) { 16244 id = parseVariableIdentifier(); 16245 } 16246 16247 if (matchKeyword('extends')) { 16248 lex(); 16249 superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall); 16250 } 16251 classBody = parseClassBody(); 16252 strict = previousStrict; 16253 16254 return classNode.finishClassExpression(id, superClass, classBody); 16255 } 16256 16257 // ECMA-262 15.2 Modules 16258 16259 function parseModuleSpecifier() { 16260 var node = new Node(); 16261 16262 if (lookahead.type !== Token.StringLiteral) { 16263 throwError(Messages.InvalidModuleSpecifier); 16264 } 16265 return node.finishLiteral(lex()); 16266 } 16267 16268 // ECMA-262 15.2.3 Exports 16269 16270 function parseExportSpecifier() { 16271 var exported, local, node = new Node(), def; 16272 if (matchKeyword('default')) { 16273 // export {default} from 'something'; 16274 def = new Node(); 16275 lex(); 16276 local = def.finishIdentifier('default'); 16277 } else { 16278 local = parseVariableIdentifier(); 16279 } 16280 if (matchContextualKeyword('as')) { 16281 lex(); 16282 exported = parseNonComputedProperty(); 16283 } 16284 return node.finishExportSpecifier(local, exported); 16285 } 16286 16287 function parseExportNamedDeclaration(node) { 16288 var declaration = null, 16289 isExportFromIdentifier, 16290 src = null, specifiers = []; 16291 16292 // non-default export 16293 if (lookahead.type === Token.Keyword) { 16294 // covers: 16295 // export var f = 1; 16296 switch (lookahead.value) { 16297 case 'let': 16298 case 'const': 16299 declaration = parseLexicalDeclaration({inFor: false}); 16300 return node.finishExportNamedDeclaration(declaration, specifiers, null); 16301 case 'var': 16302 case 'class': 16303 case 'function': 16304 declaration = parseStatementListItem(); 16305 return node.finishExportNamedDeclaration(declaration, specifiers, null); 16306 } 16307 } 16308 16309 expect('{'); 16310 while (!match('}')) { 16311 isExportFromIdentifier = isExportFromIdentifier || matchKeyword('default'); 16312 specifiers.push(parseExportSpecifier()); 16313 if (!match('}')) { 16314 expect(','); 16315 if (match('}')) { 16316 break; 16317 } 16318 } 16319 } 16320 expect('}'); 16321 16322 if (matchContextualKeyword('from')) { 16323 // covering: 16324 // export {default} from 'foo'; 16325 // export {foo} from 'foo'; 16326 lex(); 16327 src = parseModuleSpecifier(); 16328 consumeSemicolon(); 16329 } else if (isExportFromIdentifier) { 16330 // covering: 16331 // export {default}; // missing fromClause 16332 throwError(lookahead.value ? 16333 Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value); 16334 } else { 16335 // cover 16336 // export {foo}; 16337 consumeSemicolon(); 16338 } 16339 return node.finishExportNamedDeclaration(declaration, specifiers, src); 16340 } 16341 16342 function parseExportDefaultDeclaration(node) { 16343 var declaration = null, 16344 expression = null; 16345 16346 // covers: 16347 // export default ... 16348 expectKeyword('default'); 16349 16350 if (matchKeyword('function')) { 16351 // covers: 16352 // export default function foo () {} 16353 // export default function () {} 16354 declaration = parseFunctionDeclaration(new Node(), true); 16355 return node.finishExportDefaultDeclaration(declaration); 16356 } 16357 if (matchKeyword('class')) { 16358 declaration = parseClassDeclaration(true); 16359 return node.finishExportDefaultDeclaration(declaration); 16360 } 16361 16362 if (matchContextualKeyword('from')) { 16363 throwError(Messages.UnexpectedToken, lookahead.value); 16364 } 16365 16366 // covers: 16367 // export default {}; 16368 // export default []; 16369 // export default (1 + 2); 16370 if (match('{')) { 16371 expression = parseObjectInitializer(); 16372 } else if (match('[')) { 16373 expression = parseArrayInitializer(); 16374 } else { 16375 expression = parseAssignmentExpression(); 16376 } 16377 consumeSemicolon(); 16378 return node.finishExportDefaultDeclaration(expression); 16379 } 16380 16381 function parseExportAllDeclaration(node) { 16382 var src; 16383 16384 // covers: 16385 // export * from 'foo'; 16386 expect('*'); 16387 if (!matchContextualKeyword('from')) { 16388 throwError(lookahead.value ? 16389 Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value); 16390 } 16391 lex(); 16392 src = parseModuleSpecifier(); 16393 consumeSemicolon(); 16394 16395 return node.finishExportAllDeclaration(src); 16396 } 16397 16398 function parseExportDeclaration() { 16399 var node = new Node(); 16400 if (state.inFunctionBody) { 16401 throwError(Messages.IllegalExportDeclaration); 16402 } 16403 16404 expectKeyword('export'); 16405 16406 if (matchKeyword('default')) { 16407 return parseExportDefaultDeclaration(node); 16408 } 16409 if (match('*')) { 16410 return parseExportAllDeclaration(node); 16411 } 16412 return parseExportNamedDeclaration(node); 16413 } 16414 16415 // ECMA-262 15.2.2 Imports 16416 16417 function parseImportSpecifier() { 16418 // import {<foo as bar>} ...; 16419 var local, imported, node = new Node(); 16420 16421 imported = parseNonComputedProperty(); 16422 if (matchContextualKeyword('as')) { 16423 lex(); 16424 local = parseVariableIdentifier(); 16425 } 16426 16427 return node.finishImportSpecifier(local, imported); 16428 } 16429 16430 function parseNamedImports() { 16431 var specifiers = []; 16432 // {foo, bar as bas} 16433 expect('{'); 16434 while (!match('}')) { 16435 specifiers.push(parseImportSpecifier()); 16436 if (!match('}')) { 16437 expect(','); 16438 if (match('}')) { 16439 break; 16440 } 16441 } 16442 } 16443 expect('}'); 16444 return specifiers; 16445 } 16446 16447 function parseImportDefaultSpecifier() { 16448 // import <foo> ...; 16449 var local, node = new Node(); 16450 16451 local = parseNonComputedProperty(); 16452 16453 return node.finishImportDefaultSpecifier(local); 16454 } 16455 16456 function parseImportNamespaceSpecifier() { 16457 // import <* as foo> ...; 16458 var local, node = new Node(); 16459 16460 expect('*'); 16461 if (!matchContextualKeyword('as')) { 16462 throwError(Messages.NoAsAfterImportNamespace); 16463 } 16464 lex(); 16465 local = parseNonComputedProperty(); 16466 16467 return node.finishImportNamespaceSpecifier(local); 16468 } 16469 16470 function parseImportDeclaration() { 16471 var specifiers = [], src, node = new Node(); 16472 16473 if (state.inFunctionBody) { 16474 throwError(Messages.IllegalImportDeclaration); 16475 } 16476 16477 expectKeyword('import'); 16478 16479 if (lookahead.type === Token.StringLiteral) { 16480 // import 'foo'; 16481 src = parseModuleSpecifier(); 16482 } else { 16483 16484 if (match('{')) { 16485 // import {bar} 16486 specifiers = specifiers.concat(parseNamedImports()); 16487 } else if (match('*')) { 16488 // import * as foo 16489 specifiers.push(parseImportNamespaceSpecifier()); 16490 } else if (isIdentifierName(lookahead) && !matchKeyword('default')) { 16491 // import foo 16492 specifiers.push(parseImportDefaultSpecifier()); 16493 if (match(',')) { 16494 lex(); 16495 if (match('*')) { 16496 // import foo, * as foo 16497 specifiers.push(parseImportNamespaceSpecifier()); 16498 } else if (match('{')) { 16499 // import foo, {bar} 16500 specifiers = specifiers.concat(parseNamedImports()); 16501 } else { 16502 throwUnexpectedToken(lookahead); 16503 } 16504 } 16505 } else { 16506 throwUnexpectedToken(lex()); 16507 } 16508 16509 if (!matchContextualKeyword('from')) { 16510 throwError(lookahead.value ? 16511 Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value); 16512 } 16513 lex(); 16514 src = parseModuleSpecifier(); 16515 } 16516 16517 consumeSemicolon(); 16518 return node.finishImportDeclaration(specifiers, src); 16519 } 16520 16521 // ECMA-262 15.1 Scripts 16522 16523 function parseScriptBody() { 16524 var statement, body = [], token, directive, firstRestricted; 16525 16526 while (startIndex < length) { 16527 token = lookahead; 16528 if (token.type !== Token.StringLiteral) { 16529 break; 16530 } 16531 16532 statement = parseStatementListItem(); 16533 body.push(statement); 16534 if (statement.expression.type !== Syntax.Literal) { 16535 // this is not directive 16536 break; 16537 } 16538 directive = source.slice(token.start + 1, token.end - 1); 16539 if (directive === 'use strict') { 16540 strict = true; 16541 if (firstRestricted) { 16542 tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral); 16543 } 16544 } else { 16545 if (!firstRestricted && token.octal) { 16546 firstRestricted = token; 16547 } 16548 } 16549 } 16550 16551 while (startIndex < length) { 16552 statement = parseStatementListItem(); 16553 /* istanbul ignore if */ 16554 if (typeof statement === 'undefined') { 16555 break; 16556 } 16557 body.push(statement); 16558 } 16559 return body; 16560 } 16561 16562 function parseProgram() { 16563 var body, node; 16564 16565 peek(); 16566 node = new Node(); 16567 16568 body = parseScriptBody(); 16569 return node.finishProgram(body, state.sourceType); 16570 } 16571 16572 function filterTokenLocation() { 16573 var i, entry, token, tokens = []; 16574 16575 for (i = 0; i < extra.tokens.length; ++i) { 16576 entry = extra.tokens[i]; 16577 token = { 16578 type: entry.type, 16579 value: entry.value 16580 }; 16581 if (entry.regex) { 16582 token.regex = { 16583 pattern: entry.regex.pattern, 16584 flags: entry.regex.flags 16585 }; 16586 } 16587 if (extra.range) { 16588 token.range = entry.range; 16589 } 16590 if (extra.loc) { 16591 token.loc = entry.loc; 16592 } 16593 tokens.push(token); 16594 } 16595 16596 extra.tokens = tokens; 16597 } 16598 16599 function tokenize(code, options, delegate) { 16600 var toString, 16601 tokens; 16602 16603 toString = String; 16604 if (typeof code !== 'string' && !(code instanceof String)) { 16605 code = toString(code); 16606 } 16607 16608 source = code; 16609 index = 0; 16610 lineNumber = (source.length > 0) ? 1 : 0; 16611 lineStart = 0; 16612 startIndex = index; 16613 startLineNumber = lineNumber; 16614 startLineStart = lineStart; 16615 length = source.length; 16616 lookahead = null; 16617 state = { 16618 allowIn: true, 16619 allowYield: true, 16620 labelSet: {}, 16621 inFunctionBody: false, 16622 inIteration: false, 16623 inSwitch: false, 16624 lastCommentStart: -1, 16625 curlyStack: [] 16626 }; 16627 16628 extra = {}; 16629 16630 // Options matching. 16631 options = options || {}; 16632 16633 // Of course we collect tokens here. 16634 options.tokens = true; 16635 extra.tokens = []; 16636 extra.tokenValues = []; 16637 extra.tokenize = true; 16638 extra.delegate = delegate; 16639 16640 // The following two fields are necessary to compute the Regex tokens. 16641 extra.openParenToken = -1; 16642 extra.openCurlyToken = -1; 16643 16644 extra.range = (typeof options.range === 'boolean') && options.range; 16645 extra.loc = (typeof options.loc === 'boolean') && options.loc; 16646 16647 if (typeof options.comment === 'boolean' && options.comment) { 16648 extra.comments = []; 16649 } 16650 if (typeof options.tolerant === 'boolean' && options.tolerant) { 16651 extra.errors = []; 16652 } 16653 16654 try { 16655 peek(); 16656 if (lookahead.type === Token.EOF) { 16657 return extra.tokens; 16658 } 16659 16660 lex(); 16661 while (lookahead.type !== Token.EOF) { 16662 try { 16663 lex(); 16664 } catch (lexError) { 16665 if (extra.errors) { 16666 recordError(lexError); 16667 // We have to break on the first error 16668 // to avoid infinite loops. 16669 break; 16670 } else { 16671 throw lexError; 16672 } 16673 } 16674 } 16675 16676 tokens = extra.tokens; 16677 if (typeof extra.errors !== 'undefined') { 16678 tokens.errors = extra.errors; 16679 } 16680 } catch (e) { 16681 throw e; 16682 } finally { 16683 extra = {}; 16684 } 16685 return tokens; 16686 } 16687 16688 function parse(code, options) { 16689 var program, toString; 16690 16691 toString = String; 16692 if (typeof code !== 'string' && !(code instanceof String)) { 16693 code = toString(code); 16694 } 16695 16696 source = code; 16697 index = 0; 16698 lineNumber = (source.length > 0) ? 1 : 0; 16699 lineStart = 0; 16700 startIndex = index; 16701 startLineNumber = lineNumber; 16702 startLineStart = lineStart; 16703 length = source.length; 16704 lookahead = null; 16705 state = { 16706 allowIn: true, 16707 allowYield: true, 16708 labelSet: {}, 16709 inFunctionBody: false, 16710 inIteration: false, 16711 inSwitch: false, 16712 lastCommentStart: -1, 16713 curlyStack: [], 16714 sourceType: 'script' 16715 }; 16716 strict = false; 16717 16718 extra = {}; 16719 if (typeof options !== 'undefined') { 16720 extra.range = (typeof options.range === 'boolean') && options.range; 16721 extra.loc = (typeof options.loc === 'boolean') && options.loc; 16722 extra.attachComment = (typeof options.attachComment === 'boolean') && options.attachComment; 16723 16724 if (extra.loc && options.source !== null && options.source !== undefined) { 16725 extra.source = toString(options.source); 16726 } 16727 16728 if (typeof options.tokens === 'boolean' && options.tokens) { 16729 extra.tokens = []; 16730 } 16731 if (typeof options.comment === 'boolean' && options.comment) { 16732 extra.comments = []; 16733 } 16734 if (typeof options.tolerant === 'boolean' && options.tolerant) { 16735 extra.errors = []; 16736 } 16737 if (extra.attachComment) { 16738 extra.range = true; 16739 extra.comments = []; 16740 extra.bottomRightStack = []; 16741 extra.trailingComments = []; 16742 extra.leadingComments = []; 16743 } 16744 if (options.sourceType === 'module') { 16745 // very restrictive condition for now 16746 state.sourceType = options.sourceType; 16747 strict = true; 16748 } 16749 } 16750 16751 try { 16752 program = parseProgram(); 16753 if (typeof extra.comments !== 'undefined') { 16754 program.comments = extra.comments; 16755 } 16756 if (typeof extra.tokens !== 'undefined') { 16757 filterTokenLocation(); 16758 program.tokens = extra.tokens; 16759 } 16760 if (typeof extra.errors !== 'undefined') { 16761 program.errors = extra.errors; 16762 } 16763 } catch (e) { 16764 throw e; 16765 } finally { 16766 extra = {}; 16767 } 16768 16769 return program; 16770 } 16771 16772 // Sync with *.json manifests. 16773 exports.version = '2.7.1'; 16774 16775 exports.tokenize = tokenize; 16776 16777 exports.parse = parse; 16778 16779 // Deep copy. 16780 /* istanbul ignore next */ 16781 exports.Syntax = (function () { 16782 var name, types = {}; 16783 16784 if (typeof Object.create === 'function') { 16785 types = Object.create(null); 16786 } 16787 16788 for (name in Syntax) { 16789 if (Syntax.hasOwnProperty(name)) { 16790 types[name] = Syntax[name]; 16791 } 16792 } 16793 16794 if (typeof Object.freeze === 'function') { 16795 Object.freeze(types); 16796 } 16797 16798 return types; 16799 }()); 16800 16801 })); 16802 /* vim: set sw=4 ts=4 et tw=80 : */ 16803 16804 },{}],51:[function(require,module,exports){ 16805 /*! 16806 * node-inherit 16807 * Copyright(c) 2011 Dmitry Filatov <dfilatov@yandex-team.ru> 16808 * MIT Licensed 16809 */ 16810 16811 module.exports = require('./lib/inherit'); 16812 16813 },{"./lib/inherit":52}],52:[function(require,module,exports){ 16814 /** 16815 * @module inherit 16816 * @version 2.2.2 16817 * @author Filatov Dmitry <dfilatov@yandex-team.ru> 16818 * @description This module provides some syntax sugar for "class" declarations, constructors, mixins, "super" calls and static members. 16819 */ 16820 16821 (function(global) { 16822 16823 var hasIntrospection = (function(){'_';}).toString().indexOf('_') > -1, 16824 emptyBase = function() {}, 16825 hasOwnProperty = Object.prototype.hasOwnProperty, 16826 objCreate = Object.create || function(ptp) { 16827 var inheritance = function() {}; 16828 inheritance.prototype = ptp; 16829 return new inheritance(); 16830 }, 16831 objKeys = Object.keys || function(obj) { 16832 var res = []; 16833 for(var i in obj) { 16834 hasOwnProperty.call(obj, i) && res.push(i); 16835 } 16836 return res; 16837 }, 16838 extend = function(o1, o2) { 16839 for(var i in o2) { 16840 hasOwnProperty.call(o2, i) && (o1[i] = o2[i]); 16841 } 16842 16843 return o1; 16844 }, 16845 toStr = Object.prototype.toString, 16846 isArray = Array.isArray || function(obj) { 16847 return toStr.call(obj) === '[object Array]'; 16848 }, 16849 isFunction = function(obj) { 16850 return toStr.call(obj) === '[object Function]'; 16851 }, 16852 noOp = function() {}, 16853 needCheckProps = true, 16854 testPropObj = { toString : '' }; 16855 16856 for(var i in testPropObj) { // fucking ie hasn't toString, valueOf in for 16857 testPropObj.hasOwnProperty(i) && (needCheckProps = false); 16858 } 16859 16860 var specProps = needCheckProps? ['toString', 'valueOf'] : null; 16861 16862 function getPropList(obj) { 16863 var res = objKeys(obj); 16864 if(needCheckProps) { 16865 var specProp, i = 0; 16866 while(specProp = specProps[i++]) { 16867 obj.hasOwnProperty(specProp) && res.push(specProp); 16868 } 16869 } 16870 16871 return res; 16872 } 16873 16874 function override(base, res, add) { 16875 var addList = getPropList(add), 16876 j = 0, len = addList.length, 16877 name, prop; 16878 while(j < len) { 16879 if((name = addList[j++]) === '__self') { 16880 continue; 16881 } 16882 prop = add[name]; 16883 if(isFunction(prop) && 16884 (!hasIntrospection || prop.toString().indexOf('.__base') > -1)) { 16885 res[name] = (function(name, prop) { 16886 var baseMethod = base[name]? 16887 base[name] : 16888 name === '__constructor'? // case of inheritance from plane function 16889 res.__self.__parent : 16890 noOp; 16891 return function() { 16892 var baseSaved = this.__base; 16893 this.__base = baseMethod; 16894 var res = prop.apply(this, arguments); 16895 this.__base = baseSaved; 16896 return res; 16897 }; 16898 })(name, prop); 16899 } else { 16900 res[name] = prop; 16901 } 16902 } 16903 } 16904 16905 function applyMixins(mixins, res) { 16906 var i = 1, mixin; 16907 while(mixin = mixins[i++]) { 16908 res? 16909 isFunction(mixin)? 16910 inherit.self(res, mixin.prototype, mixin) : 16911 inherit.self(res, mixin) : 16912 res = isFunction(mixin)? 16913 inherit(mixins[0], mixin.prototype, mixin) : 16914 inherit(mixins[0], mixin); 16915 } 16916 return res || mixins[0]; 16917 } 16918 16919 /** 16920 * Creates class 16921 * @exports 16922 * @param {Function|Array} [baseClass|baseClassAndMixins] class (or class and mixins) to inherit from 16923 * @param {Object} prototypeFields 16924 * @param {Object} [staticFields] 16925 * @returns {Function} class 16926 */ 16927 function inherit() { 16928 var args = arguments, 16929 withMixins = isArray(args[0]), 16930 hasBase = withMixins || isFunction(args[0]), 16931 base = hasBase? withMixins? applyMixins(args[0]) : args[0] : emptyBase, 16932 props = args[hasBase? 1 : 0] || {}, 16933 staticProps = args[hasBase? 2 : 1], 16934 res = props.__constructor || (hasBase && base.prototype.__constructor)? 16935 function() { 16936 return this.__constructor.apply(this, arguments); 16937 } : 16938 hasBase? 16939 function() { 16940 return base.apply(this, arguments); 16941 } : 16942 function() {}; 16943 16944 if(!hasBase) { 16945 res.prototype = props; 16946 res.prototype.__self = res.prototype.constructor = res; 16947 return extend(res, staticProps); 16948 } 16949 16950 extend(res, base); 16951 16952 res.__parent = base; 16953 16954 var basePtp = base.prototype, 16955 resPtp = res.prototype = objCreate(basePtp); 16956 16957 resPtp.__self = resPtp.constructor = res; 16958 16959 props && override(basePtp, resPtp, props); 16960 staticProps && override(base, res, staticProps); 16961 16962 return res; 16963 } 16964 16965 inherit.self = function() { 16966 var args = arguments, 16967 withMixins = isArray(args[0]), 16968 base = withMixins? applyMixins(args[0], args[0][0]) : args[0], 16969 props = args[1], 16970 staticProps = args[2], 16971 basePtp = base.prototype; 16972 16973 props && override(basePtp, basePtp, props); 16974 staticProps && override(base, base, staticProps); 16975 16976 return base; 16977 }; 16978 16979 var defineAsGlobal = true; 16980 if(typeof exports === 'object') { 16981 module.exports = inherit; 16982 defineAsGlobal = false; 16983 } 16984 16985 if(typeof modules === 'object') { 16986 modules.define('inherit', function(provide) { 16987 provide(inherit); 16988 }); 16989 defineAsGlobal = false; 16990 } 16991 16992 if(typeof define === 'function') { 16993 define(function(require, exports, module) { 16994 module.exports = inherit; 16995 }); 16996 defineAsGlobal = false; 16997 } 16998 16999 defineAsGlobal && (global.inherit = inherit); 17000 17001 })(this); 17002 17003 },{}],53:[function(require,module,exports){ 17004 var baseIndexOf = require('../internal/baseIndexOf'), 17005 binaryIndex = require('../internal/binaryIndex'); 17006 17007 /* Native method references for those with the same name as other `lodash` methods. */ 17008 var nativeMax = Math.max; 17009 17010 /** 17011 * Gets the index at which the first occurrence of `value` is found in `array` 17012 * using [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero) 17013 * for equality comparisons. If `fromIndex` is negative, it's used as the offset 17014 * from the end of `array`. If `array` is sorted providing `true` for `fromIndex` 17015 * performs a faster binary search. 17016 * 17017 * @static 17018 * @memberOf _ 17019 * @category Array 17020 * @param {Array} array The array to search. 17021 * @param {*} value The value to search for. 17022 * @param {boolean|number} [fromIndex=0] The index to search from or `true` 17023 * to perform a binary search on a sorted array. 17024 * @returns {number} Returns the index of the matched value, else `-1`. 17025 * @example 17026 * 17027 * _.indexOf([1, 2, 1, 2], 2); 17028 * // => 1 17029 * 17030 * // using `fromIndex` 17031 * _.indexOf([1, 2, 1, 2], 2, 2); 17032 * // => 3 17033 * 17034 * // performing a binary search 17035 * _.indexOf([1, 1, 2, 2], 2, true); 17036 * // => 2 17037 */ 17038 function indexOf(array, value, fromIndex) { 17039 var length = array ? array.length : 0; 17040 if (!length) { 17041 return -1; 17042 } 17043 if (typeof fromIndex == 'number') { 17044 fromIndex = fromIndex < 0 ? nativeMax(length + fromIndex, 0) : fromIndex; 17045 } else if (fromIndex) { 17046 var index = binaryIndex(array, value); 17047 if (index < length && 17048 (value === value ? (value === array[index]) : (array[index] !== array[index]))) { 17049 return index; 17050 } 17051 return -1; 17052 } 17053 return baseIndexOf(array, value, fromIndex || 0); 17054 } 17055 17056 module.exports = indexOf; 17057 17058 },{"../internal/baseIndexOf":82,"../internal/binaryIndex":96}],54:[function(require,module,exports){ 17059 /** 17060 * Gets the last element of `array`. 17061 * 17062 * @static 17063 * @memberOf _ 17064 * @category Array 17065 * @param {Array} array The array to query. 17066 * @returns {*} Returns the last element of `array`. 17067 * @example 17068 * 17069 * _.last([1, 2, 3]); 17070 * // => 3 17071 */ 17072 function last(array) { 17073 var length = array ? array.length : 0; 17074 return length ? array[length - 1] : undefined; 17075 } 17076 17077 module.exports = last; 17078 17079 },{}],55:[function(require,module,exports){ 17080 var LazyWrapper = require('../internal/LazyWrapper'), 17081 LodashWrapper = require('../internal/LodashWrapper'), 17082 baseLodash = require('../internal/baseLodash'), 17083 isArray = require('../lang/isArray'), 17084 isObjectLike = require('../internal/isObjectLike'), 17085 wrapperClone = require('../internal/wrapperClone'); 17086 17087 /** Used for native method references. */ 17088 var objectProto = Object.prototype; 17089 17090 /** Used to check objects for own properties. */ 17091 var hasOwnProperty = objectProto.hasOwnProperty; 17092 17093 /** 17094 * Creates a `lodash` object which wraps `value` to enable implicit chaining. 17095 * Methods that operate on and return arrays, collections, and functions can 17096 * be chained together. Methods that retrieve a single value or may return a 17097 * primitive value will automatically end the chain returning the unwrapped 17098 * value. Explicit chaining may be enabled using `_.chain`. The execution of 17099 * chained methods is lazy, that is, execution is deferred until `_#value` 17100 * is implicitly or explicitly called. 17101 * 17102 * Lazy evaluation allows several methods to support shortcut fusion. Shortcut 17103 * fusion is an optimization strategy which merge iteratee calls; this can help 17104 * to avoid the creation of intermediate data structures and greatly reduce the 17105 * number of iteratee executions. 17106 * 17107 * Chaining is supported in custom builds as long as the `_#value` method is 17108 * directly or indirectly included in the build. 17109 * 17110 * In addition to lodash methods, wrappers have `Array` and `String` methods. 17111 * 17112 * The wrapper `Array` methods are: 17113 * `concat`, `join`, `pop`, `push`, `reverse`, `shift`, `slice`, `sort`, 17114 * `splice`, and `unshift` 17115 * 17116 * The wrapper `String` methods are: 17117 * `replace` and `split` 17118 * 17119 * The wrapper methods that support shortcut fusion are: 17120 * `compact`, `drop`, `dropRight`, `dropRightWhile`, `dropWhile`, `filter`, 17121 * `first`, `initial`, `last`, `map`, `pluck`, `reject`, `rest`, `reverse`, 17122 * `slice`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, `toArray`, 17123 * and `where` 17124 * 17125 * The chainable wrapper methods are: 17126 * `after`, `ary`, `assign`, `at`, `before`, `bind`, `bindAll`, `bindKey`, 17127 * `callback`, `chain`, `chunk`, `commit`, `compact`, `concat`, `constant`, 17128 * `countBy`, `create`, `curry`, `debounce`, `defaults`, `defaultsDeep`, 17129 * `defer`, `delay`, `difference`, `drop`, `dropRight`, `dropRightWhile`, 17130 * `dropWhile`, `fill`, `filter`, `flatten`, `flattenDeep`, `flow`, `flowRight`, 17131 * `forEach`, `forEachRight`, `forIn`, `forInRight`, `forOwn`, `forOwnRight`, 17132 * `functions`, `groupBy`, `indexBy`, `initial`, `intersection`, `invert`, 17133 * `invoke`, `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, 17134 * `matchesProperty`, `memoize`, `merge`, `method`, `methodOf`, `mixin`, 17135 * `modArgs`, `negate`, `omit`, `once`, `pairs`, `partial`, `partialRight`, 17136 * `partition`, `pick`, `plant`, `pluck`, `property`, `propertyOf`, `pull`, 17137 * `pullAt`, `push`, `range`, `rearg`, `reject`, `remove`, `rest`, `restParam`, 17138 * `reverse`, `set`, `shuffle`, `slice`, `sort`, `sortBy`, `sortByAll`, 17139 * `sortByOrder`, `splice`, `spread`, `take`, `takeRight`, `takeRightWhile`, 17140 * `takeWhile`, `tap`, `throttle`, `thru`, `times`, `toArray`, `toPlainObject`, 17141 * `transform`, `union`, `uniq`, `unshift`, `unzip`, `unzipWith`, `values`, 17142 * `valuesIn`, `where`, `without`, `wrap`, `xor`, `zip`, `zipObject`, `zipWith` 17143 * 17144 * The wrapper methods that are **not** chainable by default are: 17145 * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clone`, `cloneDeep`, 17146 * `deburr`, `endsWith`, `escape`, `escapeRegExp`, `every`, `find`, `findIndex`, 17147 * `findKey`, `findLast`, `findLastIndex`, `findLastKey`, `findWhere`, `first`, 17148 * `floor`, `get`, `gt`, `gte`, `has`, `identity`, `includes`, `indexOf`, 17149 * `inRange`, `isArguments`, `isArray`, `isBoolean`, `isDate`, `isElement`, 17150 * `isEmpty`, `isEqual`, `isError`, `isFinite` `isFunction`, `isMatch`, 17151 * `isNative`, `isNaN`, `isNull`, `isNumber`, `isObject`, `isPlainObject`, 17152 * `isRegExp`, `isString`, `isUndefined`, `isTypedArray`, `join`, `kebabCase`, 17153 * `last`, `lastIndexOf`, `lt`, `lte`, `max`, `min`, `noConflict`, `noop`, 17154 * `now`, `pad`, `padLeft`, `padRight`, `parseInt`, `pop`, `random`, `reduce`, 17155 * `reduceRight`, `repeat`, `result`, `round`, `runInContext`, `shift`, `size`, 17156 * `snakeCase`, `some`, `sortedIndex`, `sortedLastIndex`, `startCase`, 17157 * `startsWith`, `sum`, `template`, `trim`, `trimLeft`, `trimRight`, `trunc`, 17158 * `unescape`, `uniqueId`, `value`, and `words` 17159 * 17160 * The wrapper method `sample` will return a wrapped value when `n` is provided, 17161 * otherwise an unwrapped value is returned. 17162 * 17163 * @name _ 17164 * @constructor 17165 * @category Chain 17166 * @param {*} value The value to wrap in a `lodash` instance. 17167 * @returns {Object} Returns the new `lodash` wrapper instance. 17168 * @example 17169 * 17170 * var wrapped = _([1, 2, 3]); 17171 * 17172 * // returns an unwrapped value 17173 * wrapped.reduce(function(total, n) { 17174 * return total + n; 17175 * }); 17176 * // => 6 17177 * 17178 * // returns a wrapped value 17179 * var squares = wrapped.map(function(n) { 17180 * return n * n; 17181 * }); 17182 * 17183 * _.isArray(squares); 17184 * // => false 17185 * 17186 * _.isArray(squares.value()); 17187 * // => true 17188 */ 17189 function lodash(value) { 17190 if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) { 17191 if (value instanceof LodashWrapper) { 17192 return value; 17193 } 17194 if (hasOwnProperty.call(value, '__chain__') && hasOwnProperty.call(value, '__wrapped__')) { 17195 return wrapperClone(value); 17196 } 17197 } 17198 return new LodashWrapper(value); 17199 } 17200 17201 // Ensure wrappers are instances of `baseLodash`. 17202 lodash.prototype = baseLodash.prototype; 17203 17204 module.exports = lodash; 17205 17206 },{"../internal/LazyWrapper":64,"../internal/LodashWrapper":65,"../internal/baseLodash":86,"../internal/isObjectLike":130,"../internal/wrapperClone":141,"../lang/isArray":144}],56:[function(require,module,exports){ 17207 module.exports = require('./forEach'); 17208 17209 },{"./forEach":58}],57:[function(require,module,exports){ 17210 var baseEach = require('../internal/baseEach'), 17211 createFind = require('../internal/createFind'); 17212 17213 /** 17214 * Iterates over elements of `collection`, returning the first element 17215 * `predicate` returns truthy for. The predicate is bound to `thisArg` and 17216 * invoked with three arguments: (value, index|key, collection). 17217 * 17218 * If a property name is provided for `predicate` the created `_.property` 17219 * style callback returns the property value of the given element. 17220 * 17221 * If a value is also provided for `thisArg` the created `_.matchesProperty` 17222 * style callback returns `true` for elements that have a matching property 17223 * value, else `false`. 17224 * 17225 * If an object is provided for `predicate` the created `_.matches` style 17226 * callback returns `true` for elements that have the properties of the given 17227 * object, else `false`. 17228 * 17229 * @static 17230 * @memberOf _ 17231 * @alias detect 17232 * @category Collection 17233 * @param {Array|Object|string} collection The collection to search. 17234 * @param {Function|Object|string} [predicate=_.identity] The function invoked 17235 * per iteration. 17236 * @param {*} [thisArg] The `this` binding of `predicate`. 17237 * @returns {*} Returns the matched element, else `undefined`. 17238 * @example 17239 * 17240 * var users = [ 17241 * { 'user': 'barney', 'age': 36, 'active': true }, 17242 * { 'user': 'fred', 'age': 40, 'active': false }, 17243 * { 'user': 'pebbles', 'age': 1, 'active': true } 17244 * ]; 17245 * 17246 * _.result(_.find(users, function(chr) { 17247 * return chr.age < 40; 17248 * }), 'user'); 17249 * // => 'barney' 17250 * 17251 * // using the `_.matches` callback shorthand 17252 * _.result(_.find(users, { 'age': 1, 'active': true }), 'user'); 17253 * // => 'pebbles' 17254 * 17255 * // using the `_.matchesProperty` callback shorthand 17256 * _.result(_.find(users, 'active', false), 'user'); 17257 * // => 'fred' 17258 * 17259 * // using the `_.property` callback shorthand 17260 * _.result(_.find(users, 'active'), 'user'); 17261 * // => 'barney' 17262 */ 17263 var find = createFind(baseEach); 17264 17265 module.exports = find; 17266 17267 },{"../internal/baseEach":75,"../internal/createFind":106}],58:[function(require,module,exports){ 17268 var arrayEach = require('../internal/arrayEach'), 17269 baseEach = require('../internal/baseEach'), 17270 createForEach = require('../internal/createForEach'); 17271 17272 /** 17273 * Iterates over elements of `collection` invoking `iteratee` for each element. 17274 * The `iteratee` is bound to `thisArg` and invoked with three arguments: 17275 * (value, index|key, collection). Iteratee functions may exit iteration early 17276 * by explicitly returning `false`. 17277 * 17278 * **Note:** As with other "Collections" methods, objects with a "length" property 17279 * are iterated like arrays. To avoid this behavior `_.forIn` or `_.forOwn` 17280 * may be used for object iteration. 17281 * 17282 * @static 17283 * @memberOf _ 17284 * @alias each 17285 * @category Collection 17286 * @param {Array|Object|string} collection The collection to iterate over. 17287 * @param {Function} [iteratee=_.identity] The function invoked per iteration. 17288 * @param {*} [thisArg] The `this` binding of `iteratee`. 17289 * @returns {Array|Object|string} Returns `collection`. 17290 * @example 17291 * 17292 * _([1, 2]).forEach(function(n) { 17293 * console.log(n); 17294 * }).value(); 17295 * // => logs each value from left to right and returns the array 17296 * 17297 * _.forEach({ 'a': 1, 'b': 2 }, function(n, key) { 17298 * console.log(n, key); 17299 * }); 17300 * // => logs each value-key pair and returns the object (iteration order is not guaranteed) 17301 */ 17302 var forEach = createForEach(arrayEach, baseEach); 17303 17304 module.exports = forEach; 17305 17306 },{"../internal/arrayEach":67,"../internal/baseEach":75,"../internal/createForEach":107}],59:[function(require,module,exports){ 17307 var baseIndexOf = require('../internal/baseIndexOf'), 17308 getLength = require('../internal/getLength'), 17309 isArray = require('../lang/isArray'), 17310 isIterateeCall = require('../internal/isIterateeCall'), 17311 isLength = require('../internal/isLength'), 17312 isString = require('../lang/isString'), 17313 values = require('../object/values'); 17314 17315 /* Native method references for those with the same name as other `lodash` methods. */ 17316 var nativeMax = Math.max; 17317 17318 /** 17319 * Checks if `target` is in `collection` using 17320 * [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero) 17321 * for equality comparisons. If `fromIndex` is negative, it's used as the offset 17322 * from the end of `collection`. 17323 * 17324 * @static 17325 * @memberOf _ 17326 * @alias contains, include 17327 * @category Collection 17328 * @param {Array|Object|string} collection The collection to search. 17329 * @param {*} target The value to search for. 17330 * @param {number} [fromIndex=0] The index to search from. 17331 * @param- {Object} [guard] Enables use as a callback for functions like `_.reduce`. 17332 * @returns {boolean} Returns `true` if a matching element is found, else `false`. 17333 * @example 17334 * 17335 * _.includes([1, 2, 3], 1); 17336 * // => true 17337 * 17338 * _.includes([1, 2, 3], 1, 2); 17339 * // => false 17340 * 17341 * _.includes({ 'user': 'fred', 'age': 40 }, 'fred'); 17342 * // => true 17343 * 17344 * _.includes('pebbles', 'eb'); 17345 * // => true 17346 */ 17347 function includes(collection, target, fromIndex, guard) { 17348 var length = collection ? getLength(collection) : 0; 17349 if (!isLength(length)) { 17350 collection = values(collection); 17351 length = collection.length; 17352 } 17353 if (typeof fromIndex != 'number' || (guard && isIterateeCall(target, fromIndex, guard))) { 17354 fromIndex = 0; 17355 } else { 17356 fromIndex = fromIndex < 0 ? nativeMax(length + fromIndex, 0) : (fromIndex || 0); 17357 } 17358 return (typeof collection == 'string' || !isArray(collection) && isString(collection)) 17359 ? (fromIndex <= length && collection.indexOf(target, fromIndex) > -1) 17360 : (!!length && baseIndexOf(collection, target, fromIndex) > -1); 17361 } 17362 17363 module.exports = includes; 17364 17365 },{"../internal/baseIndexOf":82,"../internal/getLength":116,"../internal/isIterateeCall":126,"../internal/isLength":129,"../lang/isArray":144,"../lang/isString":150,"../object/values":156}],60:[function(require,module,exports){ 17366 var arrayMap = require('../internal/arrayMap'), 17367 baseCallback = require('../internal/baseCallback'), 17368 baseMap = require('../internal/baseMap'), 17369 isArray = require('../lang/isArray'); 17370 17371 /** 17372 * Creates an array of values by running each element in `collection` through 17373 * `iteratee`. The `iteratee` is bound to `thisArg` and invoked with three 17374 * arguments: (value, index|key, collection). 17375 * 17376 * If a property name is provided for `iteratee` the created `_.property` 17377 * style callback returns the property value of the given element. 17378 * 17379 * If a value is also provided for `thisArg` the created `_.matchesProperty` 17380 * style callback returns `true` for elements that have a matching property 17381 * value, else `false`. 17382 * 17383 * If an object is provided for `iteratee` the created `_.matches` style 17384 * callback returns `true` for elements that have the properties of the given 17385 * object, else `false`. 17386 * 17387 * Many lodash methods are guarded to work as iteratees for methods like 17388 * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`. 17389 * 17390 * The guarded methods are: 17391 * `ary`, `callback`, `chunk`, `clone`, `create`, `curry`, `curryRight`, 17392 * `drop`, `dropRight`, `every`, `fill`, `flatten`, `invert`, `max`, `min`, 17393 * `parseInt`, `slice`, `sortBy`, `take`, `takeRight`, `template`, `trim`, 17394 * `trimLeft`, `trimRight`, `trunc`, `random`, `range`, `sample`, `some`, 17395 * `sum`, `uniq`, and `words` 17396 * 17397 * @static 17398 * @memberOf _ 17399 * @alias collect 17400 * @category Collection 17401 * @param {Array|Object|string} collection The collection to iterate over. 17402 * @param {Function|Object|string} [iteratee=_.identity] The function invoked 17403 * per iteration. 17404 * @param {*} [thisArg] The `this` binding of `iteratee`. 17405 * @returns {Array} Returns the new mapped array. 17406 * @example 17407 * 17408 * function timesThree(n) { 17409 * return n * 3; 17410 * } 17411 * 17412 * _.map([1, 2], timesThree); 17413 * // => [3, 6] 17414 * 17415 * _.map({ 'a': 1, 'b': 2 }, timesThree); 17416 * // => [3, 6] (iteration order is not guaranteed) 17417 * 17418 * var users = [ 17419 * { 'user': 'barney' }, 17420 * { 'user': 'fred' } 17421 * ]; 17422 * 17423 * // using the `_.property` callback shorthand 17424 * _.map(users, 'user'); 17425 * // => ['barney', 'fred'] 17426 */ 17427 function map(collection, iteratee, thisArg) { 17428 var func = isArray(collection) ? arrayMap : baseMap; 17429 iteratee = baseCallback(iteratee, thisArg, 3); 17430 return func(collection, iteratee); 17431 } 17432 17433 module.exports = map; 17434 17435 },{"../internal/arrayMap":68,"../internal/baseCallback":71,"../internal/baseMap":87,"../lang/isArray":144}],61:[function(require,module,exports){ 17436 var getNative = require('../internal/getNative'); 17437 17438 /* Native method references for those with the same name as other `lodash` methods. */ 17439 var nativeNow = getNative(Date, 'now'); 17440 17441 /** 17442 * Gets the number of milliseconds that have elapsed since the Unix epoch 17443 * (1 January 1970 00:00:00 UTC). 17444 * 17445 * @static 17446 * @memberOf _ 17447 * @category Date 17448 * @example 17449 * 17450 * _.defer(function(stamp) { 17451 * console.log(_.now() - stamp); 17452 * }, _.now()); 17453 * // => logs the number of milliseconds it took for the deferred function to be invoked 17454 */ 17455 var now = nativeNow || function() { 17456 return new Date().getTime(); 17457 }; 17458 17459 module.exports = now; 17460 17461 },{"../internal/getNative":118}],62:[function(require,module,exports){ 17462 var createWrapper = require('../internal/createWrapper'), 17463 replaceHolders = require('../internal/replaceHolders'), 17464 restParam = require('./restParam'); 17465 17466 /** Used to compose bitmasks for wrapper metadata. */ 17467 var BIND_FLAG = 1, 17468 PARTIAL_FLAG = 32; 17469 17470 /** 17471 * Creates a function that invokes `func` with the `this` binding of `thisArg` 17472 * and prepends any additional `_.bind` arguments to those provided to the 17473 * bound function. 17474 * 17475 * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds, 17476 * may be used as a placeholder for partially applied arguments. 17477 * 17478 * **Note:** Unlike native `Function#bind` this method does not set the "length" 17479 * property of bound functions. 17480 * 17481 * @static 17482 * @memberOf _ 17483 * @category Function 17484 * @param {Function} func The function to bind. 17485 * @param {*} thisArg The `this` binding of `func`. 17486 * @param {...*} [partials] The arguments to be partially applied. 17487 * @returns {Function} Returns the new bound function. 17488 * @example 17489 * 17490 * var greet = function(greeting, punctuation) { 17491 * return greeting + ' ' + this.user + punctuation; 17492 * }; 17493 * 17494 * var object = { 'user': 'fred' }; 17495 * 17496 * var bound = _.bind(greet, object, 'hi'); 17497 * bound('!'); 17498 * // => 'hi fred!' 17499 * 17500 * // using placeholders 17501 * var bound = _.bind(greet, object, _, '!'); 17502 * bound('hi'); 17503 * // => 'hi fred!' 17504 */ 17505 var bind = restParam(function(func, thisArg, partials) { 17506 var bitmask = BIND_FLAG; 17507 if (partials.length) { 17508 var holders = replaceHolders(partials, bind.placeholder); 17509 bitmask |= PARTIAL_FLAG; 17510 } 17511 return createWrapper(func, bitmask, thisArg, partials, holders); 17512 }); 17513 17514 // Assign default placeholders. 17515 bind.placeholder = {}; 17516 17517 module.exports = bind; 17518 17519 },{"../internal/createWrapper":110,"../internal/replaceHolders":136,"./restParam":63}],63:[function(require,module,exports){ 17520 /** Used as the `TypeError` message for "Functions" methods. */ 17521 var FUNC_ERROR_TEXT = 'Expected a function'; 17522 17523 /* Native method references for those with the same name as other `lodash` methods. */ 17524 var nativeMax = Math.max; 17525 17526 /** 17527 * Creates a function that invokes `func` with the `this` binding of the 17528 * created function and arguments from `start` and beyond provided as an array. 17529 * 17530 * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters). 17531 * 17532 * @static 17533 * @memberOf _ 17534 * @category Function 17535 * @param {Function} func The function to apply a rest parameter to. 17536 * @param {number} [start=func.length-1] The start position of the rest parameter. 17537 * @returns {Function} Returns the new function. 17538 * @example 17539 * 17540 * var say = _.restParam(function(what, names) { 17541 * return what + ' ' + _.initial(names).join(', ') + 17542 * (_.size(names) > 1 ? ', & ' : '') + _.last(names); 17543 * }); 17544 * 17545 * say('hello', 'fred', 'barney', 'pebbles'); 17546 * // => 'hello fred, barney, & pebbles' 17547 */ 17548 function restParam(func, start) { 17549 if (typeof func != 'function') { 17550 throw new TypeError(FUNC_ERROR_TEXT); 17551 } 17552 start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0); 17553 return function() { 17554 var args = arguments, 17555 index = -1, 17556 length = nativeMax(args.length - start, 0), 17557 rest = Array(length); 17558 17559 while (++index < length) { 17560 rest[index] = args[start + index]; 17561 } 17562 switch (start) { 17563 case 0: return func.call(this, rest); 17564 case 1: return func.call(this, args[0], rest); 17565 case 2: return func.call(this, args[0], args[1], rest); 17566 } 17567 var otherArgs = Array(start + 1); 17568 index = -1; 17569 while (++index < start) { 17570 otherArgs[index] = args[index]; 17571 } 17572 otherArgs[start] = rest; 17573 return func.apply(this, otherArgs); 17574 }; 17575 } 17576 17577 module.exports = restParam; 17578 17579 },{}],64:[function(require,module,exports){ 17580 var baseCreate = require('./baseCreate'), 17581 baseLodash = require('./baseLodash'); 17582 17583 /** Used as references for `-Infinity` and `Infinity`. */ 17584 var POSITIVE_INFINITY = Number.POSITIVE_INFINITY; 17585 17586 /** 17587 * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation. 17588 * 17589 * @private 17590 * @param {*} value The value to wrap. 17591 */ 17592 function LazyWrapper(value) { 17593 this.__wrapped__ = value; 17594 this.__actions__ = []; 17595 this.__dir__ = 1; 17596 this.__filtered__ = false; 17597 this.__iteratees__ = []; 17598 this.__takeCount__ = POSITIVE_INFINITY; 17599 this.__views__ = []; 17600 } 17601 17602 LazyWrapper.prototype = baseCreate(baseLodash.prototype); 17603 LazyWrapper.prototype.constructor = LazyWrapper; 17604 17605 module.exports = LazyWrapper; 17606 17607 },{"./baseCreate":74,"./baseLodash":86}],65:[function(require,module,exports){ 17608 var baseCreate = require('./baseCreate'), 17609 baseLodash = require('./baseLodash'); 17610 17611 /** 17612 * The base constructor for creating `lodash` wrapper objects. 17613 * 17614 * @private 17615 * @param {*} value The value to wrap. 17616 * @param {boolean} [chainAll] Enable chaining for all wrapper methods. 17617 * @param {Array} [actions=[]] Actions to peform to resolve the unwrapped value. 17618 */ 17619 function LodashWrapper(value, chainAll, actions) { 17620 this.__wrapped__ = value; 17621 this.__actions__ = actions || []; 17622 this.__chain__ = !!chainAll; 17623 } 17624 17625 LodashWrapper.prototype = baseCreate(baseLodash.prototype); 17626 LodashWrapper.prototype.constructor = LodashWrapper; 17627 17628 module.exports = LodashWrapper; 17629 17630 },{"./baseCreate":74,"./baseLodash":86}],66:[function(require,module,exports){ 17631 /** 17632 * Copies the values of `source` to `array`. 17633 * 17634 * @private 17635 * @param {Array} source The array to copy values from. 17636 * @param {Array} [array=[]] The array to copy values to. 17637 * @returns {Array} Returns `array`. 17638 */ 17639 function arrayCopy(source, array) { 17640 var index = -1, 17641 length = source.length; 17642 17643 array || (array = Array(length)); 17644 while (++index < length) { 17645 array[index] = source[index]; 17646 } 17647 return array; 17648 } 17649 17650 module.exports = arrayCopy; 17651 17652 },{}],67:[function(require,module,exports){ 17653 /** 17654 * A specialized version of `_.forEach` for arrays without support for callback 17655 * shorthands and `this` binding. 17656 * 17657 * @private 17658 * @param {Array} array The array to iterate over. 17659 * @param {Function} iteratee The function invoked per iteration. 17660 * @returns {Array} Returns `array`. 17661 */ 17662 function arrayEach(array, iteratee) { 17663 var index = -1, 17664 length = array.length; 17665 17666 while (++index < length) { 17667 if (iteratee(array[index], index, array) === false) { 17668 break; 17669 } 17670 } 17671 return array; 17672 } 17673 17674 module.exports = arrayEach; 17675 17676 },{}],68:[function(require,module,exports){ 17677 /** 17678 * A specialized version of `_.map` for arrays without support for callback 17679 * shorthands and `this` binding. 17680 * 17681 * @private 17682 * @param {Array} array The array to iterate over. 17683 * @param {Function} iteratee The function invoked per iteration. 17684 * @returns {Array} Returns the new mapped array. 17685 */ 17686 function arrayMap(array, iteratee) { 17687 var index = -1, 17688 length = array.length, 17689 result = Array(length); 17690 17691 while (++index < length) { 17692 result[index] = iteratee(array[index], index, array); 17693 } 17694 return result; 17695 } 17696 17697 module.exports = arrayMap; 17698 17699 },{}],69:[function(require,module,exports){ 17700 /** 17701 * A specialized version of `_.some` for arrays without support for callback 17702 * shorthands and `this` binding. 17703 * 17704 * @private 17705 * @param {Array} array The array to iterate over. 17706 * @param {Function} predicate The function invoked per iteration. 17707 * @returns {boolean} Returns `true` if any element passes the predicate check, 17708 * else `false`. 17709 */ 17710 function arraySome(array, predicate) { 17711 var index = -1, 17712 length = array.length; 17713 17714 while (++index < length) { 17715 if (predicate(array[index], index, array)) { 17716 return true; 17717 } 17718 } 17719 return false; 17720 } 17721 17722 module.exports = arraySome; 17723 17724 },{}],70:[function(require,module,exports){ 17725 var baseCopy = require('./baseCopy'), 17726 keys = require('../object/keys'); 17727 17728 /** 17729 * The base implementation of `_.assign` without support for argument juggling, 17730 * multiple sources, and `customizer` functions. 17731 * 17732 * @private 17733 * @param {Object} object The destination object. 17734 * @param {Object} source The source object. 17735 * @returns {Object} Returns `object`. 17736 */ 17737 function baseAssign(object, source) { 17738 return source == null 17739 ? object 17740 : baseCopy(source, keys(source), object); 17741 } 17742 17743 module.exports = baseAssign; 17744 17745 },{"../object/keys":153,"./baseCopy":73}],71:[function(require,module,exports){ 17746 var baseMatches = require('./baseMatches'), 17747 baseMatchesProperty = require('./baseMatchesProperty'), 17748 bindCallback = require('./bindCallback'), 17749 identity = require('../utility/identity'), 17750 property = require('../utility/property'); 17751 17752 /** 17753 * The base implementation of `_.callback` which supports specifying the 17754 * number of arguments to provide to `func`. 17755 * 17756 * @private 17757 * @param {*} [func=_.identity] The value to convert to a callback. 17758 * @param {*} [thisArg] The `this` binding of `func`. 17759 * @param {number} [argCount] The number of arguments to provide to `func`. 17760 * @returns {Function} Returns the callback. 17761 */ 17762 function baseCallback(func, thisArg, argCount) { 17763 var type = typeof func; 17764 if (type == 'function') { 17765 return thisArg === undefined 17766 ? func 17767 : bindCallback(func, thisArg, argCount); 17768 } 17769 if (func == null) { 17770 return identity; 17771 } 17772 if (type == 'object') { 17773 return baseMatches(func); 17774 } 17775 return thisArg === undefined 17776 ? property(func) 17777 : baseMatchesProperty(func, thisArg); 17778 } 17779 17780 module.exports = baseCallback; 17781 17782 },{"../utility/identity":158,"../utility/property":160,"./baseMatches":88,"./baseMatchesProperty":89,"./bindCallback":98}],72:[function(require,module,exports){ 17783 var arrayCopy = require('./arrayCopy'), 17784 arrayEach = require('./arrayEach'), 17785 baseAssign = require('./baseAssign'), 17786 baseForOwn = require('./baseForOwn'), 17787 initCloneArray = require('./initCloneArray'), 17788 initCloneByTag = require('./initCloneByTag'), 17789 initCloneObject = require('./initCloneObject'), 17790 isArray = require('../lang/isArray'), 17791 isHostObject = require('./isHostObject'), 17792 isObject = require('../lang/isObject'); 17793 17794 /** `Object#toString` result references. */ 17795 var argsTag = '[object Arguments]', 17796 arrayTag = '[object Array]', 17797 boolTag = '[object Boolean]', 17798 dateTag = '[object Date]', 17799 errorTag = '[object Error]', 17800 funcTag = '[object Function]', 17801 mapTag = '[object Map]', 17802 numberTag = '[object Number]', 17803 objectTag = '[object Object]', 17804 regexpTag = '[object RegExp]', 17805 setTag = '[object Set]', 17806 stringTag = '[object String]', 17807 weakMapTag = '[object WeakMap]'; 17808 17809 var arrayBufferTag = '[object ArrayBuffer]', 17810 float32Tag = '[object Float32Array]', 17811 float64Tag = '[object Float64Array]', 17812 int8Tag = '[object Int8Array]', 17813 int16Tag = '[object Int16Array]', 17814 int32Tag = '[object Int32Array]', 17815 uint8Tag = '[object Uint8Array]', 17816 uint8ClampedTag = '[object Uint8ClampedArray]', 17817 uint16Tag = '[object Uint16Array]', 17818 uint32Tag = '[object Uint32Array]'; 17819 17820 /** Used to identify `toStringTag` values supported by `_.clone`. */ 17821 var cloneableTags = {}; 17822 cloneableTags[argsTag] = cloneableTags[arrayTag] = 17823 cloneableTags[arrayBufferTag] = cloneableTags[boolTag] = 17824 cloneableTags[dateTag] = cloneableTags[float32Tag] = 17825 cloneableTags[float64Tag] = cloneableTags[int8Tag] = 17826 cloneableTags[int16Tag] = cloneableTags[int32Tag] = 17827 cloneableTags[numberTag] = cloneableTags[objectTag] = 17828 cloneableTags[regexpTag] = cloneableTags[stringTag] = 17829 cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] = 17830 cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true; 17831 cloneableTags[errorTag] = cloneableTags[funcTag] = 17832 cloneableTags[mapTag] = cloneableTags[setTag] = 17833 cloneableTags[weakMapTag] = false; 17834 17835 /** Used for native method references. */ 17836 var objectProto = Object.prototype; 17837 17838 /** 17839 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 17840 * of values. 17841 */ 17842 var objToString = objectProto.toString; 17843 17844 /** 17845 * The base implementation of `_.clone` without support for argument juggling 17846 * and `this` binding `customizer` functions. 17847 * 17848 * @private 17849 * @param {*} value The value to clone. 17850 * @param {boolean} [isDeep] Specify a deep clone. 17851 * @param {Function} [customizer] The function to customize cloning values. 17852 * @param {string} [key] The key of `value`. 17853 * @param {Object} [object] The object `value` belongs to. 17854 * @param {Array} [stackA=[]] Tracks traversed source objects. 17855 * @param {Array} [stackB=[]] Associates clones with source counterparts. 17856 * @returns {*} Returns the cloned value. 17857 */ 17858 function baseClone(value, isDeep, customizer, key, object, stackA, stackB) { 17859 var result; 17860 if (customizer) { 17861 result = object ? customizer(value, key, object) : customizer(value); 17862 } 17863 if (result !== undefined) { 17864 return result; 17865 } 17866 if (!isObject(value)) { 17867 return value; 17868 } 17869 var isArr = isArray(value); 17870 if (isArr) { 17871 result = initCloneArray(value); 17872 if (!isDeep) { 17873 return arrayCopy(value, result); 17874 } 17875 } else { 17876 var tag = objToString.call(value), 17877 isFunc = tag == funcTag; 17878 17879 if (tag == objectTag || tag == argsTag || (isFunc && !object)) { 17880 if (isHostObject(value)) { 17881 return object ? value : {}; 17882 } 17883 result = initCloneObject(isFunc ? {} : value); 17884 if (!isDeep) { 17885 return baseAssign(result, value); 17886 } 17887 } else { 17888 return cloneableTags[tag] 17889 ? initCloneByTag(value, tag, isDeep) 17890 : (object ? value : {}); 17891 } 17892 } 17893 // Check for circular references and return its corresponding clone. 17894 stackA || (stackA = []); 17895 stackB || (stackB = []); 17896 17897 var length = stackA.length; 17898 while (length--) { 17899 if (stackA[length] == value) { 17900 return stackB[length]; 17901 } 17902 } 17903 // Add the source value to the stack of traversed objects and associate it with its clone. 17904 stackA.push(value); 17905 stackB.push(result); 17906 17907 // Recursively populate clone (susceptible to call stack limits). 17908 (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) { 17909 result[key] = baseClone(subValue, isDeep, customizer, key, value, stackA, stackB); 17910 }); 17911 return result; 17912 } 17913 17914 module.exports = baseClone; 17915 17916 },{"../lang/isArray":144,"../lang/isObject":148,"./arrayCopy":66,"./arrayEach":67,"./baseAssign":70,"./baseForOwn":80,"./initCloneArray":120,"./initCloneByTag":121,"./initCloneObject":122,"./isHostObject":124}],73:[function(require,module,exports){ 17917 /** 17918 * Copies properties of `source` to `object`. 17919 * 17920 * @private 17921 * @param {Object} source The object to copy properties from. 17922 * @param {Array} props The property names to copy. 17923 * @param {Object} [object={}] The object to copy properties to. 17924 * @returns {Object} Returns `object`. 17925 */ 17926 function baseCopy(source, props, object) { 17927 object || (object = {}); 17928 17929 var index = -1, 17930 length = props.length; 17931 17932 while (++index < length) { 17933 var key = props[index]; 17934 object[key] = source[key]; 17935 } 17936 return object; 17937 } 17938 17939 module.exports = baseCopy; 17940 17941 },{}],74:[function(require,module,exports){ 17942 var isObject = require('../lang/isObject'); 17943 17944 /** 17945 * The base implementation of `_.create` without support for assigning 17946 * properties to the created object. 17947 * 17948 * @private 17949 * @param {Object} prototype The object to inherit from. 17950 * @returns {Object} Returns the new object. 17951 */ 17952 var baseCreate = (function() { 17953 function object() {} 17954 return function(prototype) { 17955 if (isObject(prototype)) { 17956 object.prototype = prototype; 17957 var result = new object; 17958 object.prototype = undefined; 17959 } 17960 return result || {}; 17961 }; 17962 }()); 17963 17964 module.exports = baseCreate; 17965 17966 },{"../lang/isObject":148}],75:[function(require,module,exports){ 17967 var baseForOwn = require('./baseForOwn'), 17968 createBaseEach = require('./createBaseEach'); 17969 17970 /** 17971 * The base implementation of `_.forEach` without support for callback 17972 * shorthands and `this` binding. 17973 * 17974 * @private 17975 * @param {Array|Object|string} collection The collection to iterate over. 17976 * @param {Function} iteratee The function invoked per iteration. 17977 * @returns {Array|Object|string} Returns `collection`. 17978 */ 17979 var baseEach = createBaseEach(baseForOwn); 17980 17981 module.exports = baseEach; 17982 17983 },{"./baseForOwn":80,"./createBaseEach":102}],76:[function(require,module,exports){ 17984 /** 17985 * The base implementation of `_.find`, `_.findLast`, `_.findKey`, and `_.findLastKey`, 17986 * without support for callback shorthands and `this` binding, which iterates 17987 * over `collection` using the provided `eachFunc`. 17988 * 17989 * @private 17990 * @param {Array|Object|string} collection The collection to search. 17991 * @param {Function} predicate The function invoked per iteration. 17992 * @param {Function} eachFunc The function to iterate over `collection`. 17993 * @param {boolean} [retKey] Specify returning the key of the found element 17994 * instead of the element itself. 17995 * @returns {*} Returns the found element or its key, else `undefined`. 17996 */ 17997 function baseFind(collection, predicate, eachFunc, retKey) { 17998 var result; 17999 eachFunc(collection, function(value, key, collection) { 18000 if (predicate(value, key, collection)) { 18001 result = retKey ? key : value; 18002 return false; 18003 } 18004 }); 18005 return result; 18006 } 18007 18008 module.exports = baseFind; 18009 18010 },{}],77:[function(require,module,exports){ 18011 /** 18012 * The base implementation of `_.findIndex` and `_.findLastIndex` without 18013 * support for callback shorthands and `this` binding. 18014 * 18015 * @private 18016 * @param {Array} array The array to search. 18017 * @param {Function} predicate The function invoked per iteration. 18018 * @param {boolean} [fromRight] Specify iterating from right to left. 18019 * @returns {number} Returns the index of the matched value, else `-1`. 18020 */ 18021 function baseFindIndex(array, predicate, fromRight) { 18022 var length = array.length, 18023 index = fromRight ? length : -1; 18024 18025 while ((fromRight ? index-- : ++index < length)) { 18026 if (predicate(array[index], index, array)) { 18027 return index; 18028 } 18029 } 18030 return -1; 18031 } 18032 18033 module.exports = baseFindIndex; 18034 18035 },{}],78:[function(require,module,exports){ 18036 var createBaseFor = require('./createBaseFor'); 18037 18038 /** 18039 * The base implementation of `baseForIn` and `baseForOwn` which iterates 18040 * over `object` properties returned by `keysFunc` invoking `iteratee` for 18041 * each property. Iteratee functions may exit iteration early by explicitly 18042 * returning `false`. 18043 * 18044 * @private 18045 * @param {Object} object The object to iterate over. 18046 * @param {Function} iteratee The function invoked per iteration. 18047 * @param {Function} keysFunc The function to get the keys of `object`. 18048 * @returns {Object} Returns `object`. 18049 */ 18050 var baseFor = createBaseFor(); 18051 18052 module.exports = baseFor; 18053 18054 },{"./createBaseFor":103}],79:[function(require,module,exports){ 18055 var baseFor = require('./baseFor'), 18056 keysIn = require('../object/keysIn'); 18057 18058 /** 18059 * The base implementation of `_.forIn` without support for callback 18060 * shorthands and `this` binding. 18061 * 18062 * @private 18063 * @param {Object} object The object to iterate over. 18064 * @param {Function} iteratee The function invoked per iteration. 18065 * @returns {Object} Returns `object`. 18066 */ 18067 function baseForIn(object, iteratee) { 18068 return baseFor(object, iteratee, keysIn); 18069 } 18070 18071 module.exports = baseForIn; 18072 18073 },{"../object/keysIn":154,"./baseFor":78}],80:[function(require,module,exports){ 18074 var baseFor = require('./baseFor'), 18075 keys = require('../object/keys'); 18076 18077 /** 18078 * The base implementation of `_.forOwn` without support for callback 18079 * shorthands and `this` binding. 18080 * 18081 * @private 18082 * @param {Object} object The object to iterate over. 18083 * @param {Function} iteratee The function invoked per iteration. 18084 * @returns {Object} Returns `object`. 18085 */ 18086 function baseForOwn(object, iteratee) { 18087 return baseFor(object, iteratee, keys); 18088 } 18089 18090 module.exports = baseForOwn; 18091 18092 },{"../object/keys":153,"./baseFor":78}],81:[function(require,module,exports){ 18093 var toObject = require('./toObject'); 18094 18095 /** 18096 * The base implementation of `get` without support for string paths 18097 * and default values. 18098 * 18099 * @private 18100 * @param {Object} object The object to query. 18101 * @param {Array} path The path of the property to get. 18102 * @param {string} [pathKey] The key representation of path. 18103 * @returns {*} Returns the resolved value. 18104 */ 18105 function baseGet(object, path, pathKey) { 18106 if (object == null) { 18107 return; 18108 } 18109 object = toObject(object); 18110 if (pathKey !== undefined && pathKey in object) { 18111 path = [pathKey]; 18112 } 18113 var index = 0, 18114 length = path.length; 18115 18116 while (object != null && index < length) { 18117 object = toObject(object)[path[index++]]; 18118 } 18119 return (index && index == length) ? object : undefined; 18120 } 18121 18122 module.exports = baseGet; 18123 18124 },{"./toObject":139}],82:[function(require,module,exports){ 18125 var indexOfNaN = require('./indexOfNaN'); 18126 18127 /** 18128 * The base implementation of `_.indexOf` without support for binary searches. 18129 * 18130 * @private 18131 * @param {Array} array The array to search. 18132 * @param {*} value The value to search for. 18133 * @param {number} fromIndex The index to search from. 18134 * @returns {number} Returns the index of the matched value, else `-1`. 18135 */ 18136 function baseIndexOf(array, value, fromIndex) { 18137 if (value !== value) { 18138 return indexOfNaN(array, fromIndex); 18139 } 18140 var index = fromIndex - 1, 18141 length = array.length; 18142 18143 while (++index < length) { 18144 if (array[index] === value) { 18145 return index; 18146 } 18147 } 18148 return -1; 18149 } 18150 18151 module.exports = baseIndexOf; 18152 18153 },{"./indexOfNaN":119}],83:[function(require,module,exports){ 18154 var baseIsEqualDeep = require('./baseIsEqualDeep'), 18155 isObject = require('../lang/isObject'), 18156 isObjectLike = require('./isObjectLike'); 18157 18158 /** 18159 * The base implementation of `_.isEqual` without support for `this` binding 18160 * `customizer` functions. 18161 * 18162 * @private 18163 * @param {*} value The value to compare. 18164 * @param {*} other The other value to compare. 18165 * @param {Function} [customizer] The function to customize comparing values. 18166 * @param {boolean} [isLoose] Specify performing partial comparisons. 18167 * @param {Array} [stackA] Tracks traversed `value` objects. 18168 * @param {Array} [stackB] Tracks traversed `other` objects. 18169 * @returns {boolean} Returns `true` if the values are equivalent, else `false`. 18170 */ 18171 function baseIsEqual(value, other, customizer, isLoose, stackA, stackB) { 18172 if (value === other) { 18173 return true; 18174 } 18175 if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) { 18176 return value !== value && other !== other; 18177 } 18178 return baseIsEqualDeep(value, other, baseIsEqual, customizer, isLoose, stackA, stackB); 18179 } 18180 18181 module.exports = baseIsEqual; 18182 18183 },{"../lang/isObject":148,"./baseIsEqualDeep":84,"./isObjectLike":130}],84:[function(require,module,exports){ 18184 var equalArrays = require('./equalArrays'), 18185 equalByTag = require('./equalByTag'), 18186 equalObjects = require('./equalObjects'), 18187 isArray = require('../lang/isArray'), 18188 isHostObject = require('./isHostObject'), 18189 isTypedArray = require('../lang/isTypedArray'); 18190 18191 /** `Object#toString` result references. */ 18192 var argsTag = '[object Arguments]', 18193 arrayTag = '[object Array]', 18194 objectTag = '[object Object]'; 18195 18196 /** Used for native method references. */ 18197 var objectProto = Object.prototype; 18198 18199 /** Used to check objects for own properties. */ 18200 var hasOwnProperty = objectProto.hasOwnProperty; 18201 18202 /** 18203 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 18204 * of values. 18205 */ 18206 var objToString = objectProto.toString; 18207 18208 /** 18209 * A specialized version of `baseIsEqual` for arrays and objects which performs 18210 * deep comparisons and tracks traversed objects enabling objects with circular 18211 * references to be compared. 18212 * 18213 * @private 18214 * @param {Object} object The object to compare. 18215 * @param {Object} other The other object to compare. 18216 * @param {Function} equalFunc The function to determine equivalents of values. 18217 * @param {Function} [customizer] The function to customize comparing objects. 18218 * @param {boolean} [isLoose] Specify performing partial comparisons. 18219 * @param {Array} [stackA=[]] Tracks traversed `value` objects. 18220 * @param {Array} [stackB=[]] Tracks traversed `other` objects. 18221 * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. 18222 */ 18223 function baseIsEqualDeep(object, other, equalFunc, customizer, isLoose, stackA, stackB) { 18224 var objIsArr = isArray(object), 18225 othIsArr = isArray(other), 18226 objTag = arrayTag, 18227 othTag = arrayTag; 18228 18229 if (!objIsArr) { 18230 objTag = objToString.call(object); 18231 if (objTag == argsTag) { 18232 objTag = objectTag; 18233 } else if (objTag != objectTag) { 18234 objIsArr = isTypedArray(object); 18235 } 18236 } 18237 if (!othIsArr) { 18238 othTag = objToString.call(other); 18239 if (othTag == argsTag) { 18240 othTag = objectTag; 18241 } else if (othTag != objectTag) { 18242 othIsArr = isTypedArray(other); 18243 } 18244 } 18245 var objIsObj = objTag == objectTag && !isHostObject(object), 18246 othIsObj = othTag == objectTag && !isHostObject(other), 18247 isSameTag = objTag == othTag; 18248 18249 if (isSameTag && !(objIsArr || objIsObj)) { 18250 return equalByTag(object, other, objTag); 18251 } 18252 if (!isLoose) { 18253 var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'), 18254 othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__'); 18255 18256 if (objIsWrapped || othIsWrapped) { 18257 return equalFunc(objIsWrapped ? object.value() : object, othIsWrapped ? other.value() : other, customizer, isLoose, stackA, stackB); 18258 } 18259 } 18260 if (!isSameTag) { 18261 return false; 18262 } 18263 // Assume cyclic values are equal. 18264 // For more information on detecting circular references see https://es5.github.io/#JO. 18265 stackA || (stackA = []); 18266 stackB || (stackB = []); 18267 18268 var length = stackA.length; 18269 while (length--) { 18270 if (stackA[length] == object) { 18271 return stackB[length] == other; 18272 } 18273 } 18274 // Add `object` and `other` to the stack of traversed objects. 18275 stackA.push(object); 18276 stackB.push(other); 18277 18278 var result = (objIsArr ? equalArrays : equalObjects)(object, other, equalFunc, customizer, isLoose, stackA, stackB); 18279 18280 stackA.pop(); 18281 stackB.pop(); 18282 18283 return result; 18284 } 18285 18286 module.exports = baseIsEqualDeep; 18287 18288 },{"../lang/isArray":144,"../lang/isTypedArray":151,"./equalArrays":111,"./equalByTag":112,"./equalObjects":113,"./isHostObject":124}],85:[function(require,module,exports){ 18289 var baseIsEqual = require('./baseIsEqual'), 18290 toObject = require('./toObject'); 18291 18292 /** 18293 * The base implementation of `_.isMatch` without support for callback 18294 * shorthands and `this` binding. 18295 * 18296 * @private 18297 * @param {Object} object The object to inspect. 18298 * @param {Array} matchData The propery names, values, and compare flags to match. 18299 * @param {Function} [customizer] The function to customize comparing objects. 18300 * @returns {boolean} Returns `true` if `object` is a match, else `false`. 18301 */ 18302 function baseIsMatch(object, matchData, customizer) { 18303 var index = matchData.length, 18304 length = index, 18305 noCustomizer = !customizer; 18306 18307 if (object == null) { 18308 return !length; 18309 } 18310 object = toObject(object); 18311 while (index--) { 18312 var data = matchData[index]; 18313 if ((noCustomizer && data[2]) 18314 ? data[1] !== object[data[0]] 18315 : !(data[0] in object) 18316 ) { 18317 return false; 18318 } 18319 } 18320 while (++index < length) { 18321 data = matchData[index]; 18322 var key = data[0], 18323 objValue = object[key], 18324 srcValue = data[1]; 18325 18326 if (noCustomizer && data[2]) { 18327 if (objValue === undefined && !(key in object)) { 18328 return false; 18329 } 18330 } else { 18331 var result = customizer ? customizer(objValue, srcValue, key) : undefined; 18332 if (!(result === undefined ? baseIsEqual(srcValue, objValue, customizer, true) : result)) { 18333 return false; 18334 } 18335 } 18336 } 18337 return true; 18338 } 18339 18340 module.exports = baseIsMatch; 18341 18342 },{"./baseIsEqual":83,"./toObject":139}],86:[function(require,module,exports){ 18343 /** 18344 * The function whose prototype all chaining wrappers inherit from. 18345 * 18346 * @private 18347 */ 18348 function baseLodash() { 18349 // No operation performed. 18350 } 18351 18352 module.exports = baseLodash; 18353 18354 },{}],87:[function(require,module,exports){ 18355 var baseEach = require('./baseEach'), 18356 isArrayLike = require('./isArrayLike'); 18357 18358 /** 18359 * The base implementation of `_.map` without support for callback shorthands 18360 * and `this` binding. 18361 * 18362 * @private 18363 * @param {Array|Object|string} collection The collection to iterate over. 18364 * @param {Function} iteratee The function invoked per iteration. 18365 * @returns {Array} Returns the new mapped array. 18366 */ 18367 function baseMap(collection, iteratee) { 18368 var index = -1, 18369 result = isArrayLike(collection) ? Array(collection.length) : []; 18370 18371 baseEach(collection, function(value, key, collection) { 18372 result[++index] = iteratee(value, key, collection); 18373 }); 18374 return result; 18375 } 18376 18377 module.exports = baseMap; 18378 18379 },{"./baseEach":75,"./isArrayLike":123}],88:[function(require,module,exports){ 18380 var baseIsMatch = require('./baseIsMatch'), 18381 getMatchData = require('./getMatchData'), 18382 toObject = require('./toObject'); 18383 18384 /** 18385 * The base implementation of `_.matches` which does not clone `source`. 18386 * 18387 * @private 18388 * @param {Object} source The object of property values to match. 18389 * @returns {Function} Returns the new function. 18390 */ 18391 function baseMatches(source) { 18392 var matchData = getMatchData(source); 18393 if (matchData.length == 1 && matchData[0][2]) { 18394 var key = matchData[0][0], 18395 value = matchData[0][1]; 18396 18397 return function(object) { 18398 if (object == null) { 18399 return false; 18400 } 18401 object = toObject(object); 18402 return object[key] === value && (value !== undefined || (key in object)); 18403 }; 18404 } 18405 return function(object) { 18406 return baseIsMatch(object, matchData); 18407 }; 18408 } 18409 18410 module.exports = baseMatches; 18411 18412 },{"./baseIsMatch":85,"./getMatchData":117,"./toObject":139}],89:[function(require,module,exports){ 18413 var baseGet = require('./baseGet'), 18414 baseIsEqual = require('./baseIsEqual'), 18415 baseSlice = require('./baseSlice'), 18416 isArray = require('../lang/isArray'), 18417 isKey = require('./isKey'), 18418 isStrictComparable = require('./isStrictComparable'), 18419 last = require('../array/last'), 18420 toObject = require('./toObject'), 18421 toPath = require('./toPath'); 18422 18423 /** 18424 * The base implementation of `_.matchesProperty` which does not clone `srcValue`. 18425 * 18426 * @private 18427 * @param {string} path The path of the property to get. 18428 * @param {*} srcValue The value to compare. 18429 * @returns {Function} Returns the new function. 18430 */ 18431 function baseMatchesProperty(path, srcValue) { 18432 var isArr = isArray(path), 18433 isCommon = isKey(path) && isStrictComparable(srcValue), 18434 pathKey = (path + ''); 18435 18436 path = toPath(path); 18437 return function(object) { 18438 if (object == null) { 18439 return false; 18440 } 18441 var key = pathKey; 18442 object = toObject(object); 18443 if ((isArr || !isCommon) && !(key in object)) { 18444 object = path.length == 1 ? object : baseGet(object, baseSlice(path, 0, -1)); 18445 if (object == null) { 18446 return false; 18447 } 18448 key = last(path); 18449 object = toObject(object); 18450 } 18451 return object[key] === srcValue 18452 ? (srcValue !== undefined || (key in object)) 18453 : baseIsEqual(srcValue, object[key], undefined, true); 18454 }; 18455 } 18456 18457 module.exports = baseMatchesProperty; 18458 18459 },{"../array/last":54,"../lang/isArray":144,"./baseGet":81,"./baseIsEqual":83,"./baseSlice":93,"./isKey":127,"./isStrictComparable":131,"./toObject":139,"./toPath":140}],90:[function(require,module,exports){ 18460 var toObject = require('./toObject'); 18461 18462 /** 18463 * The base implementation of `_.property` without support for deep paths. 18464 * 18465 * @private 18466 * @param {string} key The key of the property to get. 18467 * @returns {Function} Returns the new function. 18468 */ 18469 function baseProperty(key) { 18470 return function(object) { 18471 return object == null ? undefined : toObject(object)[key]; 18472 }; 18473 } 18474 18475 module.exports = baseProperty; 18476 18477 },{"./toObject":139}],91:[function(require,module,exports){ 18478 var baseGet = require('./baseGet'), 18479 toPath = require('./toPath'); 18480 18481 /** 18482 * A specialized version of `baseProperty` which supports deep paths. 18483 * 18484 * @private 18485 * @param {Array|string} path The path of the property to get. 18486 * @returns {Function} Returns the new function. 18487 */ 18488 function basePropertyDeep(path) { 18489 var pathKey = (path + ''); 18490 path = toPath(path); 18491 return function(object) { 18492 return baseGet(object, path, pathKey); 18493 }; 18494 } 18495 18496 module.exports = basePropertyDeep; 18497 18498 },{"./baseGet":81,"./toPath":140}],92:[function(require,module,exports){ 18499 var identity = require('../utility/identity'), 18500 metaMap = require('./metaMap'); 18501 18502 /** 18503 * The base implementation of `setData` without support for hot loop detection. 18504 * 18505 * @private 18506 * @param {Function} func The function to associate metadata with. 18507 * @param {*} data The metadata. 18508 * @returns {Function} Returns `func`. 18509 */ 18510 var baseSetData = !metaMap ? identity : function(func, data) { 18511 metaMap.set(func, data); 18512 return func; 18513 }; 18514 18515 module.exports = baseSetData; 18516 18517 },{"../utility/identity":158,"./metaMap":133}],93:[function(require,module,exports){ 18518 /** 18519 * The base implementation of `_.slice` without an iteratee call guard. 18520 * 18521 * @private 18522 * @param {Array} array The array to slice. 18523 * @param {number} [start=0] The start position. 18524 * @param {number} [end=array.length] The end position. 18525 * @returns {Array} Returns the slice of `array`. 18526 */ 18527 function baseSlice(array, start, end) { 18528 var index = -1, 18529 length = array.length; 18530 18531 start = start == null ? 0 : (+start || 0); 18532 if (start < 0) { 18533 start = -start > length ? 0 : (length + start); 18534 } 18535 end = (end === undefined || end > length) ? length : (+end || 0); 18536 if (end < 0) { 18537 end += length; 18538 } 18539 length = start > end ? 0 : ((end - start) >>> 0); 18540 start >>>= 0; 18541 18542 var result = Array(length); 18543 while (++index < length) { 18544 result[index] = array[index + start]; 18545 } 18546 return result; 18547 } 18548 18549 module.exports = baseSlice; 18550 18551 },{}],94:[function(require,module,exports){ 18552 /** 18553 * Converts `value` to a string if it's not one. An empty string is returned 18554 * for `null` or `undefined` values. 18555 * 18556 * @private 18557 * @param {*} value The value to process. 18558 * @returns {string} Returns the string. 18559 */ 18560 function baseToString(value) { 18561 return value == null ? '' : (value + ''); 18562 } 18563 18564 module.exports = baseToString; 18565 18566 },{}],95:[function(require,module,exports){ 18567 /** 18568 * The base implementation of `_.values` and `_.valuesIn` which creates an 18569 * array of `object` property values corresponding to the property names 18570 * of `props`. 18571 * 18572 * @private 18573 * @param {Object} object The object to query. 18574 * @param {Array} props The property names to get values for. 18575 * @returns {Object} Returns the array of property values. 18576 */ 18577 function baseValues(object, props) { 18578 var index = -1, 18579 length = props.length, 18580 result = Array(length); 18581 18582 while (++index < length) { 18583 result[index] = object[props[index]]; 18584 } 18585 return result; 18586 } 18587 18588 module.exports = baseValues; 18589 18590 },{}],96:[function(require,module,exports){ 18591 var binaryIndexBy = require('./binaryIndexBy'), 18592 identity = require('../utility/identity'); 18593 18594 /** Used as references for the maximum length and index of an array. */ 18595 var MAX_ARRAY_LENGTH = 4294967295, 18596 HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1; 18597 18598 /** 18599 * Performs a binary search of `array` to determine the index at which `value` 18600 * should be inserted into `array` in order to maintain its sort order. 18601 * 18602 * @private 18603 * @param {Array} array The sorted array to inspect. 18604 * @param {*} value The value to evaluate. 18605 * @param {boolean} [retHighest] Specify returning the highest qualified index. 18606 * @returns {number} Returns the index at which `value` should be inserted 18607 * into `array`. 18608 */ 18609 function binaryIndex(array, value, retHighest) { 18610 var low = 0, 18611 high = array ? array.length : low; 18612 18613 if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) { 18614 while (low < high) { 18615 var mid = (low + high) >>> 1, 18616 computed = array[mid]; 18617 18618 if ((retHighest ? (computed <= value) : (computed < value)) && computed !== null) { 18619 low = mid + 1; 18620 } else { 18621 high = mid; 18622 } 18623 } 18624 return high; 18625 } 18626 return binaryIndexBy(array, value, identity, retHighest); 18627 } 18628 18629 module.exports = binaryIndex; 18630 18631 },{"../utility/identity":158,"./binaryIndexBy":97}],97:[function(require,module,exports){ 18632 /* Native method references for those with the same name as other `lodash` methods. */ 18633 var nativeFloor = Math.floor, 18634 nativeMin = Math.min; 18635 18636 /** Used as references for the maximum length and index of an array. */ 18637 var MAX_ARRAY_LENGTH = 4294967295, 18638 MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1; 18639 18640 /** 18641 * This function is like `binaryIndex` except that it invokes `iteratee` for 18642 * `value` and each element of `array` to compute their sort ranking. The 18643 * iteratee is invoked with one argument; (value). 18644 * 18645 * @private 18646 * @param {Array} array The sorted array to inspect. 18647 * @param {*} value The value to evaluate. 18648 * @param {Function} iteratee The function invoked per iteration. 18649 * @param {boolean} [retHighest] Specify returning the highest qualified index. 18650 * @returns {number} Returns the index at which `value` should be inserted 18651 * into `array`. 18652 */ 18653 function binaryIndexBy(array, value, iteratee, retHighest) { 18654 value = iteratee(value); 18655 18656 var low = 0, 18657 high = array ? array.length : 0, 18658 valIsNaN = value !== value, 18659 valIsNull = value === null, 18660 valIsUndef = value === undefined; 18661 18662 while (low < high) { 18663 var mid = nativeFloor((low + high) / 2), 18664 computed = iteratee(array[mid]), 18665 isDef = computed !== undefined, 18666 isReflexive = computed === computed; 18667 18668 if (valIsNaN) { 18669 var setLow = isReflexive || retHighest; 18670 } else if (valIsNull) { 18671 setLow = isReflexive && isDef && (retHighest || computed != null); 18672 } else if (valIsUndef) { 18673 setLow = isReflexive && (retHighest || isDef); 18674 } else if (computed == null) { 18675 setLow = false; 18676 } else { 18677 setLow = retHighest ? (computed <= value) : (computed < value); 18678 } 18679 if (setLow) { 18680 low = mid + 1; 18681 } else { 18682 high = mid; 18683 } 18684 } 18685 return nativeMin(high, MAX_ARRAY_INDEX); 18686 } 18687 18688 module.exports = binaryIndexBy; 18689 18690 },{}],98:[function(require,module,exports){ 18691 var identity = require('../utility/identity'); 18692 18693 /** 18694 * A specialized version of `baseCallback` which only supports `this` binding 18695 * and specifying the number of arguments to provide to `func`. 18696 * 18697 * @private 18698 * @param {Function} func The function to bind. 18699 * @param {*} thisArg The `this` binding of `func`. 18700 * @param {number} [argCount] The number of arguments to provide to `func`. 18701 * @returns {Function} Returns the callback. 18702 */ 18703 function bindCallback(func, thisArg, argCount) { 18704 if (typeof func != 'function') { 18705 return identity; 18706 } 18707 if (thisArg === undefined) { 18708 return func; 18709 } 18710 switch (argCount) { 18711 case 1: return function(value) { 18712 return func.call(thisArg, value); 18713 }; 18714 case 3: return function(value, index, collection) { 18715 return func.call(thisArg, value, index, collection); 18716 }; 18717 case 4: return function(accumulator, value, index, collection) { 18718 return func.call(thisArg, accumulator, value, index, collection); 18719 }; 18720 case 5: return function(value, other, key, object, source) { 18721 return func.call(thisArg, value, other, key, object, source); 18722 }; 18723 } 18724 return function() { 18725 return func.apply(thisArg, arguments); 18726 }; 18727 } 18728 18729 module.exports = bindCallback; 18730 18731 },{"../utility/identity":158}],99:[function(require,module,exports){ 18732 (function (global){ 18733 /** Native method references. */ 18734 var ArrayBuffer = global.ArrayBuffer, 18735 Uint8Array = global.Uint8Array; 18736 18737 /** 18738 * Creates a clone of the given array buffer. 18739 * 18740 * @private 18741 * @param {ArrayBuffer} buffer The array buffer to clone. 18742 * @returns {ArrayBuffer} Returns the cloned array buffer. 18743 */ 18744 function bufferClone(buffer) { 18745 var result = new ArrayBuffer(buffer.byteLength), 18746 view = new Uint8Array(result); 18747 18748 view.set(new Uint8Array(buffer)); 18749 return result; 18750 } 18751 18752 module.exports = bufferClone; 18753 18754 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 18755 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2J1ZmZlckNsb25lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBOYXRpdmUgbWV0aG9kIHJlZmVyZW5jZXMuICovXG52YXIgQXJyYXlCdWZmZXIgPSBnbG9iYWwuQXJyYXlCdWZmZXIsXG4gICAgVWludDhBcnJheSA9IGdsb2JhbC5VaW50OEFycmF5O1xuXG4vKipcbiAqIENyZWF0ZXMgYSBjbG9uZSBvZiB0aGUgZ2l2ZW4gYXJyYXkgYnVmZmVyLlxuICpcbiAqIEBwcml2YXRlXG4gKiBAcGFyYW0ge0FycmF5QnVmZmVyfSBidWZmZXIgVGhlIGFycmF5IGJ1ZmZlciB0byBjbG9uZS5cbiAqIEByZXR1cm5zIHtBcnJheUJ1ZmZlcn0gUmV0dXJucyB0aGUgY2xvbmVkIGFycmF5IGJ1ZmZlci5cbiAqL1xuZnVuY3Rpb24gYnVmZmVyQ2xvbmUoYnVmZmVyKSB7XG4gIHZhciByZXN1bHQgPSBuZXcgQXJyYXlCdWZmZXIoYnVmZmVyLmJ5dGVMZW5ndGgpLFxuICAgICAgdmlldyA9IG5ldyBVaW50OEFycmF5KHJlc3VsdCk7XG5cbiAgdmlldy5zZXQobmV3IFVpbnQ4QXJyYXkoYnVmZmVyKSk7XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gYnVmZmVyQ2xvbmU7XG4iXX0= 18756 },{}],100:[function(require,module,exports){ 18757 /* Native method references for those with the same name as other `lodash` methods. */ 18758 var nativeMax = Math.max; 18759 18760 /** 18761 * Creates an array that is the composition of partially applied arguments, 18762 * placeholders, and provided arguments into a single array of arguments. 18763 * 18764 * @private 18765 * @param {Array|Object} args The provided arguments. 18766 * @param {Array} partials The arguments to prepend to those provided. 18767 * @param {Array} holders The `partials` placeholder indexes. 18768 * @returns {Array} Returns the new array of composed arguments. 18769 */ 18770 function composeArgs(args, partials, holders) { 18771 var holdersLength = holders.length, 18772 argsIndex = -1, 18773 argsLength = nativeMax(args.length - holdersLength, 0), 18774 leftIndex = -1, 18775 leftLength = partials.length, 18776 result = Array(leftLength + argsLength); 18777 18778 while (++leftIndex < leftLength) { 18779 result[leftIndex] = partials[leftIndex]; 18780 } 18781 while (++argsIndex < holdersLength) { 18782 result[holders[argsIndex]] = args[argsIndex]; 18783 } 18784 while (argsLength--) { 18785 result[leftIndex++] = args[argsIndex++]; 18786 } 18787 return result; 18788 } 18789 18790 module.exports = composeArgs; 18791 18792 },{}],101:[function(require,module,exports){ 18793 /* Native method references for those with the same name as other `lodash` methods. */ 18794 var nativeMax = Math.max; 18795 18796 /** 18797 * This function is like `composeArgs` except that the arguments composition 18798 * is tailored for `_.partialRight`. 18799 * 18800 * @private 18801 * @param {Array|Object} args The provided arguments. 18802 * @param {Array} partials The arguments to append to those provided. 18803 * @param {Array} holders The `partials` placeholder indexes. 18804 * @returns {Array} Returns the new array of composed arguments. 18805 */ 18806 function composeArgsRight(args, partials, holders) { 18807 var holdersIndex = -1, 18808 holdersLength = holders.length, 18809 argsIndex = -1, 18810 argsLength = nativeMax(args.length - holdersLength, 0), 18811 rightIndex = -1, 18812 rightLength = partials.length, 18813 result = Array(argsLength + rightLength); 18814 18815 while (++argsIndex < argsLength) { 18816 result[argsIndex] = args[argsIndex]; 18817 } 18818 var offset = argsIndex; 18819 while (++rightIndex < rightLength) { 18820 result[offset + rightIndex] = partials[rightIndex]; 18821 } 18822 while (++holdersIndex < holdersLength) { 18823 result[offset + holders[holdersIndex]] = args[argsIndex++]; 18824 } 18825 return result; 18826 } 18827 18828 module.exports = composeArgsRight; 18829 18830 },{}],102:[function(require,module,exports){ 18831 var getLength = require('./getLength'), 18832 isLength = require('./isLength'), 18833 toObject = require('./toObject'); 18834 18835 /** 18836 * Creates a `baseEach` or `baseEachRight` function. 18837 * 18838 * @private 18839 * @param {Function} eachFunc The function to iterate over a collection. 18840 * @param {boolean} [fromRight] Specify iterating from right to left. 18841 * @returns {Function} Returns the new base function. 18842 */ 18843 function createBaseEach(eachFunc, fromRight) { 18844 return function(collection, iteratee) { 18845 var length = collection ? getLength(collection) : 0; 18846 if (!isLength(length)) { 18847 return eachFunc(collection, iteratee); 18848 } 18849 var index = fromRight ? length : -1, 18850 iterable = toObject(collection); 18851 18852 while ((fromRight ? index-- : ++index < length)) { 18853 if (iteratee(iterable[index], index, iterable) === false) { 18854 break; 18855 } 18856 } 18857 return collection; 18858 }; 18859 } 18860 18861 module.exports = createBaseEach; 18862 18863 },{"./getLength":116,"./isLength":129,"./toObject":139}],103:[function(require,module,exports){ 18864 var toObject = require('./toObject'); 18865 18866 /** 18867 * Creates a base function for `_.forIn` or `_.forInRight`. 18868 * 18869 * @private 18870 * @param {boolean} [fromRight] Specify iterating from right to left. 18871 * @returns {Function} Returns the new base function. 18872 */ 18873 function createBaseFor(fromRight) { 18874 return function(object, iteratee, keysFunc) { 18875 var iterable = toObject(object), 18876 props = keysFunc(object), 18877 length = props.length, 18878 index = fromRight ? length : -1; 18879 18880 while ((fromRight ? index-- : ++index < length)) { 18881 var key = props[index]; 18882 if (iteratee(iterable[key], key, iterable) === false) { 18883 break; 18884 } 18885 } 18886 return object; 18887 }; 18888 } 18889 18890 module.exports = createBaseFor; 18891 18892 },{"./toObject":139}],104:[function(require,module,exports){ 18893 (function (global){ 18894 var createCtorWrapper = require('./createCtorWrapper'); 18895 18896 /** 18897 * Creates a function that wraps `func` and invokes it with the `this` 18898 * binding of `thisArg`. 18899 * 18900 * @private 18901 * @param {Function} func The function to bind. 18902 * @param {*} [thisArg] The `this` binding of `func`. 18903 * @returns {Function} Returns the new bound function. 18904 */ 18905 function createBindWrapper(func, thisArg) { 18906 var Ctor = createCtorWrapper(func); 18907 18908 function wrapper() { 18909 var fn = (this && this !== global && this instanceof wrapper) ? Ctor : func; 18910 return fn.apply(thisArg, arguments); 18911 } 18912 return wrapper; 18913 } 18914 18915 module.exports = createBindWrapper; 18916 18917 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 18918 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZUJpbmRXcmFwcGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIGFuZCBpbnZva2VzIGl0IHdpdGggdGhlIGB0aGlzYFxuICogYmluZGluZyBvZiBgdGhpc0FyZ2AuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMgVGhlIGZ1bmN0aW9uIHRvIGJpbmQuXG4gKiBAcGFyYW0geyp9IFt0aGlzQXJnXSBUaGUgYHRoaXNgIGJpbmRpbmcgb2YgYGZ1bmNgLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgYm91bmQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUJpbmRXcmFwcGVyKGZ1bmMsIHRoaXNBcmcpIHtcbiAgdmFyIEN0b3IgPSBjcmVhdGVDdG9yV3JhcHBlcihmdW5jKTtcblxuICBmdW5jdGlvbiB3cmFwcGVyKCkge1xuICAgIHZhciBmbiA9ICh0aGlzICYmIHRoaXMgIT09IGdsb2JhbCAmJiB0aGlzIGluc3RhbmNlb2Ygd3JhcHBlcikgPyBDdG9yIDogZnVuYztcbiAgICByZXR1cm4gZm4uYXBwbHkodGhpc0FyZywgYXJndW1lbnRzKTtcbiAgfVxuICByZXR1cm4gd3JhcHBlcjtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBjcmVhdGVCaW5kV3JhcHBlcjtcbiJdfQ== 18919 },{"./createCtorWrapper":105}],105:[function(require,module,exports){ 18920 var baseCreate = require('./baseCreate'), 18921 isObject = require('../lang/isObject'); 18922 18923 /** 18924 * Creates a function that produces an instance of `Ctor` regardless of 18925 * whether it was invoked as part of a `new` expression or by `call` or `apply`. 18926 * 18927 * @private 18928 * @param {Function} Ctor The constructor to wrap. 18929 * @returns {Function} Returns the new wrapped function. 18930 */ 18931 function createCtorWrapper(Ctor) { 18932 return function() { 18933 // Use a `switch` statement to work with class constructors. 18934 // See http://ecma-international.org/ecma-262/6.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist 18935 // for more details. 18936 var args = arguments; 18937 switch (args.length) { 18938 case 0: return new Ctor; 18939 case 1: return new Ctor(args[0]); 18940 case 2: return new Ctor(args[0], args[1]); 18941 case 3: return new Ctor(args[0], args[1], args[2]); 18942 case 4: return new Ctor(args[0], args[1], args[2], args[3]); 18943 case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]); 18944 case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]); 18945 case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]); 18946 } 18947 var thisBinding = baseCreate(Ctor.prototype), 18948 result = Ctor.apply(thisBinding, args); 18949 18950 // Mimic the constructor's `return` behavior. 18951 // See https://es5.github.io/#x13.2.2 for more details. 18952 return isObject(result) ? result : thisBinding; 18953 }; 18954 } 18955 18956 module.exports = createCtorWrapper; 18957 18958 },{"../lang/isObject":148,"./baseCreate":74}],106:[function(require,module,exports){ 18959 var baseCallback = require('./baseCallback'), 18960 baseFind = require('./baseFind'), 18961 baseFindIndex = require('./baseFindIndex'), 18962 isArray = require('../lang/isArray'); 18963 18964 /** 18965 * Creates a `_.find` or `_.findLast` function. 18966 * 18967 * @private 18968 * @param {Function} eachFunc The function to iterate over a collection. 18969 * @param {boolean} [fromRight] Specify iterating from right to left. 18970 * @returns {Function} Returns the new find function. 18971 */ 18972 function createFind(eachFunc, fromRight) { 18973 return function(collection, predicate, thisArg) { 18974 predicate = baseCallback(predicate, thisArg, 3); 18975 if (isArray(collection)) { 18976 var index = baseFindIndex(collection, predicate, fromRight); 18977 return index > -1 ? collection[index] : undefined; 18978 } 18979 return baseFind(collection, predicate, eachFunc); 18980 }; 18981 } 18982 18983 module.exports = createFind; 18984 18985 },{"../lang/isArray":144,"./baseCallback":71,"./baseFind":76,"./baseFindIndex":77}],107:[function(require,module,exports){ 18986 var bindCallback = require('./bindCallback'), 18987 isArray = require('../lang/isArray'); 18988 18989 /** 18990 * Creates a function for `_.forEach` or `_.forEachRight`. 18991 * 18992 * @private 18993 * @param {Function} arrayFunc The function to iterate over an array. 18994 * @param {Function} eachFunc The function to iterate over a collection. 18995 * @returns {Function} Returns the new each function. 18996 */ 18997 function createForEach(arrayFunc, eachFunc) { 18998 return function(collection, iteratee, thisArg) { 18999 return (typeof iteratee == 'function' && thisArg === undefined && isArray(collection)) 19000 ? arrayFunc(collection, iteratee) 19001 : eachFunc(collection, bindCallback(iteratee, thisArg, 3)); 19002 }; 19003 } 19004 19005 module.exports = createForEach; 19006 19007 },{"../lang/isArray":144,"./bindCallback":98}],108:[function(require,module,exports){ 19008 (function (global){ 19009 var arrayCopy = require('./arrayCopy'), 19010 composeArgs = require('./composeArgs'), 19011 composeArgsRight = require('./composeArgsRight'), 19012 createCtorWrapper = require('./createCtorWrapper'), 19013 isLaziable = require('./isLaziable'), 19014 reorder = require('./reorder'), 19015 replaceHolders = require('./replaceHolders'), 19016 setData = require('./setData'); 19017 19018 /** Used to compose bitmasks for wrapper metadata. */ 19019 var BIND_FLAG = 1, 19020 BIND_KEY_FLAG = 2, 19021 CURRY_BOUND_FLAG = 4, 19022 CURRY_FLAG = 8, 19023 CURRY_RIGHT_FLAG = 16, 19024 PARTIAL_FLAG = 32, 19025 PARTIAL_RIGHT_FLAG = 64, 19026 ARY_FLAG = 128; 19027 19028 /* Native method references for those with the same name as other `lodash` methods. */ 19029 var nativeMax = Math.max; 19030 19031 /** 19032 * Creates a function that wraps `func` and invokes it with optional `this` 19033 * binding of, partial application, and currying. 19034 * 19035 * @private 19036 * @param {Function|string} func The function or method name to reference. 19037 * @param {number} bitmask The bitmask of flags. See `createWrapper` for more details. 19038 * @param {*} [thisArg] The `this` binding of `func`. 19039 * @param {Array} [partials] The arguments to prepend to those provided to the new function. 19040 * @param {Array} [holders] The `partials` placeholder indexes. 19041 * @param {Array} [partialsRight] The arguments to append to those provided to the new function. 19042 * @param {Array} [holdersRight] The `partialsRight` placeholder indexes. 19043 * @param {Array} [argPos] The argument positions of the new function. 19044 * @param {number} [ary] The arity cap of `func`. 19045 * @param {number} [arity] The arity of `func`. 19046 * @returns {Function} Returns the new wrapped function. 19047 */ 19048 function createHybridWrapper(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) { 19049 var isAry = bitmask & ARY_FLAG, 19050 isBind = bitmask & BIND_FLAG, 19051 isBindKey = bitmask & BIND_KEY_FLAG, 19052 isCurry = bitmask & CURRY_FLAG, 19053 isCurryBound = bitmask & CURRY_BOUND_FLAG, 19054 isCurryRight = bitmask & CURRY_RIGHT_FLAG, 19055 Ctor = isBindKey ? undefined : createCtorWrapper(func); 19056 19057 function wrapper() { 19058 // Avoid `arguments` object use disqualifying optimizations by 19059 // converting it to an array before providing it to other functions. 19060 var length = arguments.length, 19061 index = length, 19062 args = Array(length); 19063 19064 while (index--) { 19065 args[index] = arguments[index]; 19066 } 19067 if (partials) { 19068 args = composeArgs(args, partials, holders); 19069 } 19070 if (partialsRight) { 19071 args = composeArgsRight(args, partialsRight, holdersRight); 19072 } 19073 if (isCurry || isCurryRight) { 19074 var placeholder = wrapper.placeholder, 19075 argsHolders = replaceHolders(args, placeholder); 19076 19077 length -= argsHolders.length; 19078 if (length < arity) { 19079 var newArgPos = argPos ? arrayCopy(argPos) : undefined, 19080 newArity = nativeMax(arity - length, 0), 19081 newsHolders = isCurry ? argsHolders : undefined, 19082 newHoldersRight = isCurry ? undefined : argsHolders, 19083 newPartials = isCurry ? args : undefined, 19084 newPartialsRight = isCurry ? undefined : args; 19085 19086 bitmask |= (isCurry ? PARTIAL_FLAG : PARTIAL_RIGHT_FLAG); 19087 bitmask &= ~(isCurry ? PARTIAL_RIGHT_FLAG : PARTIAL_FLAG); 19088 19089 if (!isCurryBound) { 19090 bitmask &= ~(BIND_FLAG | BIND_KEY_FLAG); 19091 } 19092 var newData = [func, bitmask, thisArg, newPartials, newsHolders, newPartialsRight, newHoldersRight, newArgPos, ary, newArity], 19093 result = createHybridWrapper.apply(undefined, newData); 19094 19095 if (isLaziable(func)) { 19096 setData(result, newData); 19097 } 19098 result.placeholder = placeholder; 19099 return result; 19100 } 19101 } 19102 var thisBinding = isBind ? thisArg : this, 19103 fn = isBindKey ? thisBinding[func] : func; 19104 19105 if (argPos) { 19106 args = reorder(args, argPos); 19107 } 19108 if (isAry && ary < args.length) { 19109 args.length = ary; 19110 } 19111 if (this && this !== global && this instanceof wrapper) { 19112 fn = Ctor || createCtorWrapper(func); 19113 } 19114 return fn.apply(thisBinding, args); 19115 } 19116 return wrapper; 19117 } 19118 19119 module.exports = createHybridWrapper; 19120 19121 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 19122 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZUh5YnJpZFdyYXBwZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgYXJyYXlDb3B5ID0gcmVxdWlyZSgnLi9hcnJheUNvcHknKSxcbiAgICBjb21wb3NlQXJncyA9IHJlcXVpcmUoJy4vY29tcG9zZUFyZ3MnKSxcbiAgICBjb21wb3NlQXJnc1JpZ2h0ID0gcmVxdWlyZSgnLi9jb21wb3NlQXJnc1JpZ2h0JyksXG4gICAgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyksXG4gICAgaXNMYXppYWJsZSA9IHJlcXVpcmUoJy4vaXNMYXppYWJsZScpLFxuICAgIHJlb3JkZXIgPSByZXF1aXJlKCcuL3Jlb3JkZXInKSxcbiAgICByZXBsYWNlSG9sZGVycyA9IHJlcXVpcmUoJy4vcmVwbGFjZUhvbGRlcnMnKSxcbiAgICBzZXREYXRhID0gcmVxdWlyZSgnLi9zZXREYXRhJyk7XG5cbi8qKiBVc2VkIHRvIGNvbXBvc2UgYml0bWFza3MgZm9yIHdyYXBwZXIgbWV0YWRhdGEuICovXG52YXIgQklORF9GTEFHID0gMSxcbiAgICBCSU5EX0tFWV9GTEFHID0gMixcbiAgICBDVVJSWV9CT1VORF9GTEFHID0gNCxcbiAgICBDVVJSWV9GTEFHID0gOCxcbiAgICBDVVJSWV9SSUdIVF9GTEFHID0gMTYsXG4gICAgUEFSVElBTF9GTEFHID0gMzIsXG4gICAgUEFSVElBTF9SSUdIVF9GTEFHID0gNjQsXG4gICAgQVJZX0ZMQUcgPSAxMjg7XG5cbi8qIE5hdGl2ZSBtZXRob2QgcmVmZXJlbmNlcyBmb3IgdGhvc2Ugd2l0aCB0aGUgc2FtZSBuYW1lIGFzIG90aGVyIGBsb2Rhc2hgIG1ldGhvZHMuICovXG52YXIgbmF0aXZlTWF4ID0gTWF0aC5tYXg7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIGFuZCBpbnZva2VzIGl0IHdpdGggb3B0aW9uYWwgYHRoaXNgXG4gKiBiaW5kaW5nIG9mLCBwYXJ0aWFsIGFwcGxpY2F0aW9uLCBhbmQgY3VycnlpbmcuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb258c3RyaW5nfSBmdW5jIFRoZSBmdW5jdGlvbiBvciBtZXRob2QgbmFtZSB0byByZWZlcmVuY2UuXG4gKiBAcGFyYW0ge251bWJlcn0gYml0bWFzayBUaGUgYml0bWFzayBvZiBmbGFncy4gU2VlIGBjcmVhdGVXcmFwcGVyYCBmb3IgbW9yZSBkZXRhaWxzLlxuICogQHBhcmFtIHsqfSBbdGhpc0FyZ10gVGhlIGB0aGlzYCBiaW5kaW5nIG9mIGBmdW5jYC5cbiAqIEBwYXJhbSB7QXJyYXl9IFtwYXJ0aWFsc10gVGhlIGFyZ3VtZW50cyB0byBwcmVwZW5kIHRvIHRob3NlIHByb3ZpZGVkIHRvIHRoZSBuZXcgZnVuY3Rpb24uXG4gKiBAcGFyYW0ge0FycmF5fSBbaG9sZGVyc10gVGhlIGBwYXJ0aWFsc2AgcGxhY2Vob2xkZXIgaW5kZXhlcy5cbiAqIEBwYXJhbSB7QXJyYXl9IFtwYXJ0aWFsc1JpZ2h0XSBUaGUgYXJndW1lbnRzIHRvIGFwcGVuZCB0byB0aG9zZSBwcm92aWRlZCB0byB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHBhcmFtIHtBcnJheX0gW2hvbGRlcnNSaWdodF0gVGhlIGBwYXJ0aWFsc1JpZ2h0YCBwbGFjZWhvbGRlciBpbmRleGVzLlxuICogQHBhcmFtIHtBcnJheX0gW2FyZ1Bvc10gVGhlIGFyZ3VtZW50IHBvc2l0aW9ucyBvZiB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHBhcmFtIHtudW1iZXJ9IFthcnldIFRoZSBhcml0eSBjYXAgb2YgYGZ1bmNgLlxuICogQHBhcmFtIHtudW1iZXJ9IFthcml0eV0gVGhlIGFyaXR5IG9mIGBmdW5jYC5cbiAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IHdyYXBwZWQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUh5YnJpZFdyYXBwZXIoZnVuYywgYml0bWFzaywgdGhpc0FyZywgcGFydGlhbHMsIGhvbGRlcnMsIHBhcnRpYWxzUmlnaHQsIGhvbGRlcnNSaWdodCwgYXJnUG9zLCBhcnksIGFyaXR5KSB7XG4gIHZhciBpc0FyeSA9IGJpdG1hc2sgJiBBUllfRkxBRyxcbiAgICAgIGlzQmluZCA9IGJpdG1hc2sgJiBCSU5EX0ZMQUcsXG4gICAgICBpc0JpbmRLZXkgPSBiaXRtYXNrICYgQklORF9LRVlfRkxBRyxcbiAgICAgIGlzQ3VycnkgPSBiaXRtYXNrICYgQ1VSUllfRkxBRyxcbiAgICAgIGlzQ3VycnlCb3VuZCA9IGJpdG1hc2sgJiBDVVJSWV9CT1VORF9GTEFHLFxuICAgICAgaXNDdXJyeVJpZ2h0ID0gYml0bWFzayAmIENVUlJZX1JJR0hUX0ZMQUcsXG4gICAgICBDdG9yID0gaXNCaW5kS2V5ID8gdW5kZWZpbmVkIDogY3JlYXRlQ3RvcldyYXBwZXIoZnVuYyk7XG5cbiAgZnVuY3Rpb24gd3JhcHBlcigpIHtcbiAgICAvLyBBdm9pZCBgYXJndW1lbnRzYCBvYmplY3QgdXNlIGRpc3F1YWxpZnlpbmcgb3B0aW1pemF0aW9ucyBieVxuICAgIC8vIGNvbnZlcnRpbmcgaXQgdG8gYW4gYXJyYXkgYmVmb3JlIHByb3ZpZGluZyBpdCB0byBvdGhlciBmdW5jdGlvbnMuXG4gICAgdmFyIGxlbmd0aCA9IGFyZ3VtZW50cy5sZW5ndGgsXG4gICAgICAgIGluZGV4ID0gbGVuZ3RoLFxuICAgICAgICBhcmdzID0gQXJyYXkobGVuZ3RoKTtcblxuICAgIHdoaWxlIChpbmRleC0tKSB7XG4gICAgICBhcmdzW2luZGV4XSA9IGFyZ3VtZW50c1tpbmRleF07XG4gICAgfVxuICAgIGlmIChwYXJ0aWFscykge1xuICAgICAgYXJncyA9IGNvbXBvc2VBcmdzKGFyZ3MsIHBhcnRpYWxzLCBob2xkZXJzKTtcbiAgICB9XG4gICAgaWYgKHBhcnRpYWxzUmlnaHQpIHtcbiAgICAgIGFyZ3MgPSBjb21wb3NlQXJnc1JpZ2h0KGFyZ3MsIHBhcnRpYWxzUmlnaHQsIGhvbGRlcnNSaWdodCk7XG4gICAgfVxuICAgIGlmIChpc0N1cnJ5IHx8IGlzQ3VycnlSaWdodCkge1xuICAgICAgdmFyIHBsYWNlaG9sZGVyID0gd3JhcHBlci5wbGFjZWhvbGRlcixcbiAgICAgICAgICBhcmdzSG9sZGVycyA9IHJlcGxhY2VIb2xkZXJzKGFyZ3MsIHBsYWNlaG9sZGVyKTtcblxuICAgICAgbGVuZ3RoIC09IGFyZ3NIb2xkZXJzLmxlbmd0aDtcbiAgICAgIGlmIChsZW5ndGggPCBhcml0eSkge1xuICAgICAgICB2YXIgbmV3QXJnUG9zID0gYXJnUG9zID8gYXJyYXlDb3B5KGFyZ1BvcykgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBuZXdBcml0eSA9IG5hdGl2ZU1heChhcml0eSAtIGxlbmd0aCwgMCksXG4gICAgICAgICAgICBuZXdzSG9sZGVycyA9IGlzQ3VycnkgPyBhcmdzSG9sZGVycyA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgIG5ld0hvbGRlcnNSaWdodCA9IGlzQ3VycnkgPyB1bmRlZmluZWQgOiBhcmdzSG9sZGVycyxcbiAgICAgICAgICAgIG5ld1BhcnRpYWxzID0gaXNDdXJyeSA/IGFyZ3MgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBuZXdQYXJ0aWFsc1JpZ2h0ID0gaXNDdXJyeSA/IHVuZGVmaW5lZCA6IGFyZ3M7XG5cbiAgICAgICAgYml0bWFzayB8PSAoaXNDdXJyeSA/IFBBUlRJQUxfRkxBRyA6IFBBUlRJQUxfUklHSFRfRkxBRyk7XG4gICAgICAgIGJpdG1hc2sgJj0gfihpc0N1cnJ5ID8gUEFSVElBTF9SSUdIVF9GTEFHIDogUEFSVElBTF9GTEFHKTtcblxuICAgICAgICBpZiAoIWlzQ3VycnlCb3VuZCkge1xuICAgICAgICAgIGJpdG1hc2sgJj0gfihCSU5EX0ZMQUcgfCBCSU5EX0tFWV9GTEFHKTtcbiAgICAgICAgfVxuICAgICAgICB2YXIgbmV3RGF0YSA9IFtmdW5jLCBiaXRtYXNrLCB0aGlzQXJnLCBuZXdQYXJ0aWFscywgbmV3c0hvbGRlcnMsIG5ld1BhcnRpYWxzUmlnaHQsIG5ld0hvbGRlcnNSaWdodCwgbmV3QXJnUG9zLCBhcnksIG5ld0FyaXR5XSxcbiAgICAgICAgICAgIHJlc3VsdCA9IGNyZWF0ZUh5YnJpZFdyYXBwZXIuYXBwbHkodW5kZWZpbmVkLCBuZXdEYXRhKTtcblxuICAgICAgICBpZiAoaXNMYXppYWJsZShmdW5jKSkge1xuICAgICAgICAgIHNldERhdGEocmVzdWx0LCBuZXdEYXRhKTtcbiAgICAgICAgfVxuICAgICAgICByZXN1bHQucGxhY2Vob2xkZXIgPSBwbGFjZWhvbGRlcjtcbiAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgIH1cbiAgICB9XG4gICAgdmFyIHRoaXNCaW5kaW5nID0gaXNCaW5kID8gdGhpc0FyZyA6IHRoaXMsXG4gICAgICAgIGZuID0gaXNCaW5kS2V5ID8gdGhpc0JpbmRpbmdbZnVuY10gOiBmdW5jO1xuXG4gICAgaWYgKGFyZ1Bvcykge1xuICAgICAgYXJncyA9IHJlb3JkZXIoYXJncywgYXJnUG9zKTtcbiAgICB9XG4gICAgaWYgKGlzQXJ5ICYmIGFyeSA8IGFyZ3MubGVuZ3RoKSB7XG4gICAgICBhcmdzLmxlbmd0aCA9IGFyeTtcbiAgICB9XG4gICAgaWYgKHRoaXMgJiYgdGhpcyAhPT0gZ2xvYmFsICYmIHRoaXMgaW5zdGFuY2VvZiB3cmFwcGVyKSB7XG4gICAgICBmbiA9IEN0b3IgfHwgY3JlYXRlQ3RvcldyYXBwZXIoZnVuYyk7XG4gICAgfVxuICAgIHJldHVybiBmbi5hcHBseSh0aGlzQmluZGluZywgYXJncyk7XG4gIH1cbiAgcmV0dXJuIHdyYXBwZXI7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gY3JlYXRlSHlicmlkV3JhcHBlcjtcbiJdfQ== 19123 },{"./arrayCopy":66,"./composeArgs":100,"./composeArgsRight":101,"./createCtorWrapper":105,"./isLaziable":128,"./reorder":135,"./replaceHolders":136,"./setData":137}],109:[function(require,module,exports){ 19124 (function (global){ 19125 var createCtorWrapper = require('./createCtorWrapper'); 19126 19127 /** Used to compose bitmasks for wrapper metadata. */ 19128 var BIND_FLAG = 1; 19129 19130 /** 19131 * Creates a function that wraps `func` and invokes it with the optional `this` 19132 * binding of `thisArg` and the `partials` prepended to those provided to 19133 * the wrapper. 19134 * 19135 * @private 19136 * @param {Function} func The function to partially apply arguments to. 19137 * @param {number} bitmask The bitmask of flags. See `createWrapper` for more details. 19138 * @param {*} thisArg The `this` binding of `func`. 19139 * @param {Array} partials The arguments to prepend to those provided to the new function. 19140 * @returns {Function} Returns the new bound function. 19141 */ 19142 function createPartialWrapper(func, bitmask, thisArg, partials) { 19143 var isBind = bitmask & BIND_FLAG, 19144 Ctor = createCtorWrapper(func); 19145 19146 function wrapper() { 19147 // Avoid `arguments` object use disqualifying optimizations by 19148 // converting it to an array before providing it `func`. 19149 var argsIndex = -1, 19150 argsLength = arguments.length, 19151 leftIndex = -1, 19152 leftLength = partials.length, 19153 args = Array(leftLength + argsLength); 19154 19155 while (++leftIndex < leftLength) { 19156 args[leftIndex] = partials[leftIndex]; 19157 } 19158 while (argsLength--) { 19159 args[leftIndex++] = arguments[++argsIndex]; 19160 } 19161 var fn = (this && this !== global && this instanceof wrapper) ? Ctor : func; 19162 return fn.apply(isBind ? thisArg : this, args); 19163 } 19164 return wrapper; 19165 } 19166 19167 module.exports = createPartialWrapper; 19168 19169 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 19170 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZVBhcnRpYWxXcmFwcGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyk7XG5cbi8qKiBVc2VkIHRvIGNvbXBvc2UgYml0bWFza3MgZm9yIHdyYXBwZXIgbWV0YWRhdGEuICovXG52YXIgQklORF9GTEFHID0gMTtcblxuLyoqXG4gKiBDcmVhdGVzIGEgZnVuY3Rpb24gdGhhdCB3cmFwcyBgZnVuY2AgYW5kIGludm9rZXMgaXQgd2l0aCB0aGUgb3B0aW9uYWwgYHRoaXNgXG4gKiBiaW5kaW5nIG9mIGB0aGlzQXJnYCBhbmQgdGhlIGBwYXJ0aWFsc2AgcHJlcGVuZGVkIHRvIHRob3NlIHByb3ZpZGVkIHRvXG4gKiB0aGUgd3JhcHBlci5cbiAqXG4gKiBAcHJpdmF0ZVxuICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gcGFydGlhbGx5IGFwcGx5IGFyZ3VtZW50cyB0by5cbiAqIEBwYXJhbSB7bnVtYmVyfSBiaXRtYXNrIFRoZSBiaXRtYXNrIG9mIGZsYWdzLiBTZWUgYGNyZWF0ZVdyYXBwZXJgIGZvciBtb3JlIGRldGFpbHMuXG4gKiBAcGFyYW0geyp9IHRoaXNBcmcgVGhlIGB0aGlzYCBiaW5kaW5nIG9mIGBmdW5jYC5cbiAqIEBwYXJhbSB7QXJyYXl9IHBhcnRpYWxzIFRoZSBhcmd1bWVudHMgdG8gcHJlcGVuZCB0byB0aG9zZSBwcm92aWRlZCB0byB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgYm91bmQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVBhcnRpYWxXcmFwcGVyKGZ1bmMsIGJpdG1hc2ssIHRoaXNBcmcsIHBhcnRpYWxzKSB7XG4gIHZhciBpc0JpbmQgPSBiaXRtYXNrICYgQklORF9GTEFHLFxuICAgICAgQ3RvciA9IGNyZWF0ZUN0b3JXcmFwcGVyKGZ1bmMpO1xuXG4gIGZ1bmN0aW9uIHdyYXBwZXIoKSB7XG4gICAgLy8gQXZvaWQgYGFyZ3VtZW50c2Agb2JqZWN0IHVzZSBkaXNxdWFsaWZ5aW5nIG9wdGltaXphdGlvbnMgYnlcbiAgICAvLyBjb252ZXJ0aW5nIGl0IHRvIGFuIGFycmF5IGJlZm9yZSBwcm92aWRpbmcgaXQgYGZ1bmNgLlxuICAgIHZhciBhcmdzSW5kZXggPSAtMSxcbiAgICAgICAgYXJnc0xlbmd0aCA9IGFyZ3VtZW50cy5sZW5ndGgsXG4gICAgICAgIGxlZnRJbmRleCA9IC0xLFxuICAgICAgICBsZWZ0TGVuZ3RoID0gcGFydGlhbHMubGVuZ3RoLFxuICAgICAgICBhcmdzID0gQXJyYXkobGVmdExlbmd0aCArIGFyZ3NMZW5ndGgpO1xuXG4gICAgd2hpbGUgKCsrbGVmdEluZGV4IDwgbGVmdExlbmd0aCkge1xuICAgICAgYXJnc1tsZWZ0SW5kZXhdID0gcGFydGlhbHNbbGVmdEluZGV4XTtcbiAgICB9XG4gICAgd2hpbGUgKGFyZ3NMZW5ndGgtLSkge1xuICAgICAgYXJnc1tsZWZ0SW5kZXgrK10gPSBhcmd1bWVudHNbKythcmdzSW5kZXhdO1xuICAgIH1cbiAgICB2YXIgZm4gPSAodGhpcyAmJiB0aGlzICE9PSBnbG9iYWwgJiYgdGhpcyBpbnN0YW5jZW9mIHdyYXBwZXIpID8gQ3RvciA6IGZ1bmM7XG4gICAgcmV0dXJuIGZuLmFwcGx5KGlzQmluZCA/IHRoaXNBcmcgOiB0aGlzLCBhcmdzKTtcbiAgfVxuICByZXR1cm4gd3JhcHBlcjtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBjcmVhdGVQYXJ0aWFsV3JhcHBlcjtcbiJdfQ== 19171 },{"./createCtorWrapper":105}],110:[function(require,module,exports){ 19172 var baseSetData = require('./baseSetData'), 19173 createBindWrapper = require('./createBindWrapper'), 19174 createHybridWrapper = require('./createHybridWrapper'), 19175 createPartialWrapper = require('./createPartialWrapper'), 19176 getData = require('./getData'), 19177 mergeData = require('./mergeData'), 19178 setData = require('./setData'); 19179 19180 /** Used to compose bitmasks for wrapper metadata. */ 19181 var BIND_FLAG = 1, 19182 BIND_KEY_FLAG = 2, 19183 PARTIAL_FLAG = 32, 19184 PARTIAL_RIGHT_FLAG = 64; 19185 19186 /** Used as the `TypeError` message for "Functions" methods. */ 19187 var FUNC_ERROR_TEXT = 'Expected a function'; 19188 19189 /* Native method references for those with the same name as other `lodash` methods. */ 19190 var nativeMax = Math.max; 19191 19192 /** 19193 * Creates a function that either curries or invokes `func` with optional 19194 * `this` binding and partially applied arguments. 19195 * 19196 * @private 19197 * @param {Function|string} func The function or method name to reference. 19198 * @param {number} bitmask The bitmask of flags. 19199 * The bitmask may be composed of the following flags: 19200 * 1 - `_.bind` 19201 * 2 - `_.bindKey` 19202 * 4 - `_.curry` or `_.curryRight` of a bound function 19203 * 8 - `_.curry` 19204 * 16 - `_.curryRight` 19205 * 32 - `_.partial` 19206 * 64 - `_.partialRight` 19207 * 128 - `_.rearg` 19208 * 256 - `_.ary` 19209 * @param {*} [thisArg] The `this` binding of `func`. 19210 * @param {Array} [partials] The arguments to be partially applied. 19211 * @param {Array} [holders] The `partials` placeholder indexes. 19212 * @param {Array} [argPos] The argument positions of the new function. 19213 * @param {number} [ary] The arity cap of `func`. 19214 * @param {number} [arity] The arity of `func`. 19215 * @returns {Function} Returns the new wrapped function. 19216 */ 19217 function createWrapper(func, bitmask, thisArg, partials, holders, argPos, ary, arity) { 19218 var isBindKey = bitmask & BIND_KEY_FLAG; 19219 if (!isBindKey && typeof func != 'function') { 19220 throw new TypeError(FUNC_ERROR_TEXT); 19221 } 19222 var length = partials ? partials.length : 0; 19223 if (!length) { 19224 bitmask &= ~(PARTIAL_FLAG | PARTIAL_RIGHT_FLAG); 19225 partials = holders = undefined; 19226 } 19227 length -= (holders ? holders.length : 0); 19228 if (bitmask & PARTIAL_RIGHT_FLAG) { 19229 var partialsRight = partials, 19230 holdersRight = holders; 19231 19232 partials = holders = undefined; 19233 } 19234 var data = isBindKey ? undefined : getData(func), 19235 newData = [func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity]; 19236 19237 if (data) { 19238 mergeData(newData, data); 19239 bitmask = newData[1]; 19240 arity = newData[9]; 19241 } 19242 newData[9] = arity == null 19243 ? (isBindKey ? 0 : func.length) 19244 : (nativeMax(arity - length, 0) || 0); 19245 19246 if (bitmask == BIND_FLAG) { 19247 var result = createBindWrapper(newData[0], newData[2]); 19248 } else if ((bitmask == PARTIAL_FLAG || bitmask == (BIND_FLAG | PARTIAL_FLAG)) && !newData[4].length) { 19249 result = createPartialWrapper.apply(undefined, newData); 19250 } else { 19251 result = createHybridWrapper.apply(undefined, newData); 19252 } 19253 var setter = data ? baseSetData : setData; 19254 return setter(result, newData); 19255 } 19256 19257 module.exports = createWrapper; 19258 19259 },{"./baseSetData":92,"./createBindWrapper":104,"./createHybridWrapper":108,"./createPartialWrapper":109,"./getData":114,"./mergeData":132,"./setData":137}],111:[function(require,module,exports){ 19260 var arraySome = require('./arraySome'); 19261 19262 /** 19263 * A specialized version of `baseIsEqualDeep` for arrays with support for 19264 * partial deep comparisons. 19265 * 19266 * @private 19267 * @param {Array} array The array to compare. 19268 * @param {Array} other The other array to compare. 19269 * @param {Function} equalFunc The function to determine equivalents of values. 19270 * @param {Function} [customizer] The function to customize comparing arrays. 19271 * @param {boolean} [isLoose] Specify performing partial comparisons. 19272 * @param {Array} [stackA] Tracks traversed `value` objects. 19273 * @param {Array} [stackB] Tracks traversed `other` objects. 19274 * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`. 19275 */ 19276 function equalArrays(array, other, equalFunc, customizer, isLoose, stackA, stackB) { 19277 var index = -1, 19278 arrLength = array.length, 19279 othLength = other.length; 19280 19281 if (arrLength != othLength && !(isLoose && othLength > arrLength)) { 19282 return false; 19283 } 19284 // Ignore non-index properties. 19285 while (++index < arrLength) { 19286 var arrValue = array[index], 19287 othValue = other[index], 19288 result = customizer ? customizer(isLoose ? othValue : arrValue, isLoose ? arrValue : othValue, index) : undefined; 19289 19290 if (result !== undefined) { 19291 if (result) { 19292 continue; 19293 } 19294 return false; 19295 } 19296 // Recursively compare arrays (susceptible to call stack limits). 19297 if (isLoose) { 19298 if (!arraySome(other, function(othValue) { 19299 return arrValue === othValue || equalFunc(arrValue, othValue, customizer, isLoose, stackA, stackB); 19300 })) { 19301 return false; 19302 } 19303 } else if (!(arrValue === othValue || equalFunc(arrValue, othValue, customizer, isLoose, stackA, stackB))) { 19304 return false; 19305 } 19306 } 19307 return true; 19308 } 19309 19310 module.exports = equalArrays; 19311 19312 },{"./arraySome":69}],112:[function(require,module,exports){ 19313 /** `Object#toString` result references. */ 19314 var boolTag = '[object Boolean]', 19315 dateTag = '[object Date]', 19316 errorTag = '[object Error]', 19317 numberTag = '[object Number]', 19318 regexpTag = '[object RegExp]', 19319 stringTag = '[object String]'; 19320 19321 /** 19322 * A specialized version of `baseIsEqualDeep` for comparing objects of 19323 * the same `toStringTag`. 19324 * 19325 * **Note:** This function only supports comparing values with tags of 19326 * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. 19327 * 19328 * @private 19329 * @param {Object} object The object to compare. 19330 * @param {Object} other The other object to compare. 19331 * @param {string} tag The `toStringTag` of the objects to compare. 19332 * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. 19333 */ 19334 function equalByTag(object, other, tag) { 19335 switch (tag) { 19336 case boolTag: 19337 case dateTag: 19338 // Coerce dates and booleans to numbers, dates to milliseconds and booleans 19339 // to `1` or `0` treating invalid dates coerced to `NaN` as not equal. 19340 return +object == +other; 19341 19342 case errorTag: 19343 return object.name == other.name && object.message == other.message; 19344 19345 case numberTag: 19346 // Treat `NaN` vs. `NaN` as equal. 19347 return (object != +object) 19348 ? other != +other 19349 : object == +other; 19350 19351 case regexpTag: 19352 case stringTag: 19353 // Coerce regexes to strings and treat strings primitives and string 19354 // objects as equal. See https://es5.github.io/#x15.10.6.4 for more details. 19355 return object == (other + ''); 19356 } 19357 return false; 19358 } 19359 19360 module.exports = equalByTag; 19361 19362 },{}],113:[function(require,module,exports){ 19363 var keys = require('../object/keys'); 19364 19365 /** Used for native method references. */ 19366 var objectProto = Object.prototype; 19367 19368 /** Used to check objects for own properties. */ 19369 var hasOwnProperty = objectProto.hasOwnProperty; 19370 19371 /** 19372 * A specialized version of `baseIsEqualDeep` for objects with support for 19373 * partial deep comparisons. 19374 * 19375 * @private 19376 * @param {Object} object The object to compare. 19377 * @param {Object} other The other object to compare. 19378 * @param {Function} equalFunc The function to determine equivalents of values. 19379 * @param {Function} [customizer] The function to customize comparing values. 19380 * @param {boolean} [isLoose] Specify performing partial comparisons. 19381 * @param {Array} [stackA] Tracks traversed `value` objects. 19382 * @param {Array} [stackB] Tracks traversed `other` objects. 19383 * @returns {boolean} Returns `true` if the objects are equivalent, else `false`. 19384 */ 19385 function equalObjects(object, other, equalFunc, customizer, isLoose, stackA, stackB) { 19386 var objProps = keys(object), 19387 objLength = objProps.length, 19388 othProps = keys(other), 19389 othLength = othProps.length; 19390 19391 if (objLength != othLength && !isLoose) { 19392 return false; 19393 } 19394 var index = objLength; 19395 while (index--) { 19396 var key = objProps[index]; 19397 if (!(isLoose ? key in other : hasOwnProperty.call(other, key))) { 19398 return false; 19399 } 19400 } 19401 var skipCtor = isLoose; 19402 while (++index < objLength) { 19403 key = objProps[index]; 19404 var objValue = object[key], 19405 othValue = other[key], 19406 result = customizer ? customizer(isLoose ? othValue : objValue, isLoose? objValue : othValue, key) : undefined; 19407 19408 // Recursively compare objects (susceptible to call stack limits). 19409 if (!(result === undefined ? equalFunc(objValue, othValue, customizer, isLoose, stackA, stackB) : result)) { 19410 return false; 19411 } 19412 skipCtor || (skipCtor = key == 'constructor'); 19413 } 19414 if (!skipCtor) { 19415 var objCtor = object.constructor, 19416 othCtor = other.constructor; 19417 19418 // Non `Object` object instances with different constructors are not equal. 19419 if (objCtor != othCtor && 19420 ('constructor' in object && 'constructor' in other) && 19421 !(typeof objCtor == 'function' && objCtor instanceof objCtor && 19422 typeof othCtor == 'function' && othCtor instanceof othCtor)) { 19423 return false; 19424 } 19425 } 19426 return true; 19427 } 19428 19429 module.exports = equalObjects; 19430 19431 },{"../object/keys":153}],114:[function(require,module,exports){ 19432 var metaMap = require('./metaMap'), 19433 noop = require('../utility/noop'); 19434 19435 /** 19436 * Gets metadata for `func`. 19437 * 19438 * @private 19439 * @param {Function} func The function to query. 19440 * @returns {*} Returns the metadata for `func`. 19441 */ 19442 var getData = !metaMap ? noop : function(func) { 19443 return metaMap.get(func); 19444 }; 19445 19446 module.exports = getData; 19447 19448 },{"../utility/noop":159,"./metaMap":133}],115:[function(require,module,exports){ 19449 var realNames = require('./realNames'); 19450 19451 /** 19452 * Gets the name of `func`. 19453 * 19454 * @private 19455 * @param {Function} func The function to query. 19456 * @returns {string} Returns the function name. 19457 */ 19458 function getFuncName(func) { 19459 var result = (func.name + ''), 19460 array = realNames[result], 19461 length = array ? array.length : 0; 19462 19463 while (length--) { 19464 var data = array[length], 19465 otherFunc = data.func; 19466 if (otherFunc == null || otherFunc == func) { 19467 return data.name; 19468 } 19469 } 19470 return result; 19471 } 19472 19473 module.exports = getFuncName; 19474 19475 },{"./realNames":134}],116:[function(require,module,exports){ 19476 var baseProperty = require('./baseProperty'); 19477 19478 /** 19479 * Gets the "length" property value of `object`. 19480 * 19481 * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) 19482 * that affects Safari on at least iOS 8.1-8.3 ARM64. 19483 * 19484 * @private 19485 * @param {Object} object The object to query. 19486 * @returns {*} Returns the "length" value. 19487 */ 19488 var getLength = baseProperty('length'); 19489 19490 module.exports = getLength; 19491 19492 },{"./baseProperty":90}],117:[function(require,module,exports){ 19493 var isStrictComparable = require('./isStrictComparable'), 19494 pairs = require('../object/pairs'); 19495 19496 /** 19497 * Gets the propery names, values, and compare flags of `object`. 19498 * 19499 * @private 19500 * @param {Object} object The object to query. 19501 * @returns {Array} Returns the match data of `object`. 19502 */ 19503 function getMatchData(object) { 19504 var result = pairs(object), 19505 length = result.length; 19506 19507 while (length--) { 19508 result[length][2] = isStrictComparable(result[length][1]); 19509 } 19510 return result; 19511 } 19512 19513 module.exports = getMatchData; 19514 19515 },{"../object/pairs":155,"./isStrictComparable":131}],118:[function(require,module,exports){ 19516 var isNative = require('../lang/isNative'); 19517 19518 /** 19519 * Gets the native function at `key` of `object`. 19520 * 19521 * @private 19522 * @param {Object} object The object to query. 19523 * @param {string} key The key of the method to get. 19524 * @returns {*} Returns the function if it's native, else `undefined`. 19525 */ 19526 function getNative(object, key) { 19527 var value = object == null ? undefined : object[key]; 19528 return isNative(value) ? value : undefined; 19529 } 19530 19531 module.exports = getNative; 19532 19533 },{"../lang/isNative":147}],119:[function(require,module,exports){ 19534 /** 19535 * Gets the index at which the first occurrence of `NaN` is found in `array`. 19536 * 19537 * @private 19538 * @param {Array} array The array to search. 19539 * @param {number} fromIndex The index to search from. 19540 * @param {boolean} [fromRight] Specify iterating from right to left. 19541 * @returns {number} Returns the index of the matched `NaN`, else `-1`. 19542 */ 19543 function indexOfNaN(array, fromIndex, fromRight) { 19544 var length = array.length, 19545 index = fromIndex + (fromRight ? 0 : -1); 19546 19547 while ((fromRight ? index-- : ++index < length)) { 19548 var other = array[index]; 19549 if (other !== other) { 19550 return index; 19551 } 19552 } 19553 return -1; 19554 } 19555 19556 module.exports = indexOfNaN; 19557 19558 },{}],120:[function(require,module,exports){ 19559 /** Used for native method references. */ 19560 var objectProto = Object.prototype; 19561 19562 /** Used to check objects for own properties. */ 19563 var hasOwnProperty = objectProto.hasOwnProperty; 19564 19565 /** 19566 * Initializes an array clone. 19567 * 19568 * @private 19569 * @param {Array} array The array to clone. 19570 * @returns {Array} Returns the initialized clone. 19571 */ 19572 function initCloneArray(array) { 19573 var length = array.length, 19574 result = new array.constructor(length); 19575 19576 // Add array properties assigned by `RegExp#exec`. 19577 if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) { 19578 result.index = array.index; 19579 result.input = array.input; 19580 } 19581 return result; 19582 } 19583 19584 module.exports = initCloneArray; 19585 19586 },{}],121:[function(require,module,exports){ 19587 (function (global){ 19588 var bufferClone = require('./bufferClone'); 19589 19590 /** `Object#toString` result references. */ 19591 var boolTag = '[object Boolean]', 19592 dateTag = '[object Date]', 19593 numberTag = '[object Number]', 19594 regexpTag = '[object RegExp]', 19595 stringTag = '[object String]'; 19596 19597 var arrayBufferTag = '[object ArrayBuffer]', 19598 float32Tag = '[object Float32Array]', 19599 float64Tag = '[object Float64Array]', 19600 int8Tag = '[object Int8Array]', 19601 int16Tag = '[object Int16Array]', 19602 int32Tag = '[object Int32Array]', 19603 uint8Tag = '[object Uint8Array]', 19604 uint8ClampedTag = '[object Uint8ClampedArray]', 19605 uint16Tag = '[object Uint16Array]', 19606 uint32Tag = '[object Uint32Array]'; 19607 19608 /** Used to match `RegExp` flags from their coerced string values. */ 19609 var reFlags = /\w*$/; 19610 19611 /** Native method references. */ 19612 var Uint8Array = global.Uint8Array; 19613 19614 /** Used to lookup a type array constructors by `toStringTag`. */ 19615 var ctorByTag = {}; 19616 ctorByTag[float32Tag] = global.Float32Array; 19617 ctorByTag[float64Tag] = global.Float64Array; 19618 ctorByTag[int8Tag] = global.Int8Array; 19619 ctorByTag[int16Tag] = global.Int16Array; 19620 ctorByTag[int32Tag] = global.Int32Array; 19621 ctorByTag[uint8Tag] = Uint8Array; 19622 ctorByTag[uint8ClampedTag] = global.Uint8ClampedArray; 19623 ctorByTag[uint16Tag] = global.Uint16Array; 19624 ctorByTag[uint32Tag] = global.Uint32Array; 19625 19626 /** 19627 * Initializes an object clone based on its `toStringTag`. 19628 * 19629 * **Note:** This function only supports cloning values with tags of 19630 * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`. 19631 * 19632 * @private 19633 * @param {Object} object The object to clone. 19634 * @param {string} tag The `toStringTag` of the object to clone. 19635 * @param {boolean} [isDeep] Specify a deep clone. 19636 * @returns {Object} Returns the initialized clone. 19637 */ 19638 function initCloneByTag(object, tag, isDeep) { 19639 var Ctor = object.constructor; 19640 switch (tag) { 19641 case arrayBufferTag: 19642 return bufferClone(object); 19643 19644 case boolTag: 19645 case dateTag: 19646 return new Ctor(+object); 19647 19648 case float32Tag: case float64Tag: 19649 case int8Tag: case int16Tag: case int32Tag: 19650 case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag: 19651 // Safari 5 mobile incorrectly has `Object` as the constructor of typed arrays. 19652 if (Ctor instanceof Ctor) { 19653 Ctor = ctorByTag[tag]; 19654 } 19655 var buffer = object.buffer; 19656 return new Ctor(isDeep ? bufferClone(buffer) : buffer, object.byteOffset, object.length); 19657 19658 case numberTag: 19659 case stringTag: 19660 return new Ctor(object); 19661 19662 case regexpTag: 19663 var result = new Ctor(object.source, reFlags.exec(object)); 19664 result.lastIndex = object.lastIndex; 19665 } 19666 return result; 19667 } 19668 19669 module.exports = initCloneByTag; 19670 19671 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 19672 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2luaXRDbG9uZUJ5VGFnLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgYnVmZmVyQ2xvbmUgPSByZXF1aXJlKCcuL2J1ZmZlckNsb25lJyk7XG5cbi8qKiBgT2JqZWN0I3RvU3RyaW5nYCByZXN1bHQgcmVmZXJlbmNlcy4gKi9cbnZhciBib29sVGFnID0gJ1tvYmplY3QgQm9vbGVhbl0nLFxuICAgIGRhdGVUYWcgPSAnW29iamVjdCBEYXRlXScsXG4gICAgbnVtYmVyVGFnID0gJ1tvYmplY3QgTnVtYmVyXScsXG4gICAgcmVnZXhwVGFnID0gJ1tvYmplY3QgUmVnRXhwXScsXG4gICAgc3RyaW5nVGFnID0gJ1tvYmplY3QgU3RyaW5nXSc7XG5cbnZhciBhcnJheUJ1ZmZlclRhZyA9ICdbb2JqZWN0IEFycmF5QnVmZmVyXScsXG4gICAgZmxvYXQzMlRhZyA9ICdbb2JqZWN0IEZsb2F0MzJBcnJheV0nLFxuICAgIGZsb2F0NjRUYWcgPSAnW29iamVjdCBGbG9hdDY0QXJyYXldJyxcbiAgICBpbnQ4VGFnID0gJ1tvYmplY3QgSW50OEFycmF5XScsXG4gICAgaW50MTZUYWcgPSAnW29iamVjdCBJbnQxNkFycmF5XScsXG4gICAgaW50MzJUYWcgPSAnW29iamVjdCBJbnQzMkFycmF5XScsXG4gICAgdWludDhUYWcgPSAnW29iamVjdCBVaW50OEFycmF5XScsXG4gICAgdWludDhDbGFtcGVkVGFnID0gJ1tvYmplY3QgVWludDhDbGFtcGVkQXJyYXldJyxcbiAgICB1aW50MTZUYWcgPSAnW29iamVjdCBVaW50MTZBcnJheV0nLFxuICAgIHVpbnQzMlRhZyA9ICdbb2JqZWN0IFVpbnQzMkFycmF5XSc7XG5cbi8qKiBVc2VkIHRvIG1hdGNoIGBSZWdFeHBgIGZsYWdzIGZyb20gdGhlaXIgY29lcmNlZCBzdHJpbmcgdmFsdWVzLiAqL1xudmFyIHJlRmxhZ3MgPSAvXFx3KiQvO1xuXG4vKiogTmF0aXZlIG1ldGhvZCByZWZlcmVuY2VzLiAqL1xudmFyIFVpbnQ4QXJyYXkgPSBnbG9iYWwuVWludDhBcnJheTtcblxuLyoqIFVzZWQgdG8gbG9va3VwIGEgdHlwZSBhcnJheSBjb25zdHJ1Y3RvcnMgYnkgYHRvU3RyaW5nVGFnYC4gKi9cbnZhciBjdG9yQnlUYWcgPSB7fTtcbmN0b3JCeVRhZ1tmbG9hdDMyVGFnXSA9IGdsb2JhbC5GbG9hdDMyQXJyYXk7XG5jdG9yQnlUYWdbZmxvYXQ2NFRhZ10gPSBnbG9iYWwuRmxvYXQ2NEFycmF5O1xuY3RvckJ5VGFnW2ludDhUYWddID0gZ2xvYmFsLkludDhBcnJheTtcbmN0b3JCeVRhZ1tpbnQxNlRhZ10gPSBnbG9iYWwuSW50MTZBcnJheTtcbmN0b3JCeVRhZ1tpbnQzMlRhZ10gPSBnbG9iYWwuSW50MzJBcnJheTtcbmN0b3JCeVRhZ1t1aW50OFRhZ10gPSBVaW50OEFycmF5O1xuY3RvckJ5VGFnW3VpbnQ4Q2xhbXBlZFRhZ10gPSBnbG9iYWwuVWludDhDbGFtcGVkQXJyYXk7XG5jdG9yQnlUYWdbdWludDE2VGFnXSA9IGdsb2JhbC5VaW50MTZBcnJheTtcbmN0b3JCeVRhZ1t1aW50MzJUYWddID0gZ2xvYmFsLlVpbnQzMkFycmF5O1xuXG4vKipcbiAqIEluaXRpYWxpemVzIGFuIG9iamVjdCBjbG9uZSBiYXNlZCBvbiBpdHMgYHRvU3RyaW5nVGFnYC5cbiAqXG4gKiAqKk5vdGU6KiogVGhpcyBmdW5jdGlvbiBvbmx5IHN1cHBvcnRzIGNsb25pbmcgdmFsdWVzIHdpdGggdGFncyBvZlxuICogYEJvb2xlYW5gLCBgRGF0ZWAsIGBFcnJvcmAsIGBOdW1iZXJgLCBgUmVnRXhwYCwgb3IgYFN0cmluZ2AuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmplY3QgVGhlIG9iamVjdCB0byBjbG9uZS5cbiAqIEBwYXJhbSB7c3RyaW5nfSB0YWcgVGhlIGB0b1N0cmluZ1RhZ2Agb2YgdGhlIG9iamVjdCB0byBjbG9uZS5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW2lzRGVlcF0gU3BlY2lmeSBhIGRlZXAgY2xvbmUuXG4gKiBAcmV0dXJucyB7T2JqZWN0fSBSZXR1cm5zIHRoZSBpbml0aWFsaXplZCBjbG9uZS5cbiAqL1xuZnVuY3Rpb24gaW5pdENsb25lQnlUYWcob2JqZWN0LCB0YWcsIGlzRGVlcCkge1xuICB2YXIgQ3RvciA9IG9iamVjdC5jb25zdHJ1Y3RvcjtcbiAgc3dpdGNoICh0YWcpIHtcbiAgICBjYXNlIGFycmF5QnVmZmVyVGFnOlxuICAgICAgcmV0dXJuIGJ1ZmZlckNsb25lKG9iamVjdCk7XG5cbiAgICBjYXNlIGJvb2xUYWc6XG4gICAgY2FzZSBkYXRlVGFnOlxuICAgICAgcmV0dXJuIG5ldyBDdG9yKCtvYmplY3QpO1xuXG4gICAgY2FzZSBmbG9hdDMyVGFnOiBjYXNlIGZsb2F0NjRUYWc6XG4gICAgY2FzZSBpbnQ4VGFnOiBjYXNlIGludDE2VGFnOiBjYXNlIGludDMyVGFnOlxuICAgIGNhc2UgdWludDhUYWc6IGNhc2UgdWludDhDbGFtcGVkVGFnOiBjYXNlIHVpbnQxNlRhZzogY2FzZSB1aW50MzJUYWc6XG4gICAgICAvLyBTYWZhcmkgNSBtb2JpbGUgaW5jb3JyZWN0bHkgaGFzIGBPYmplY3RgIGFzIHRoZSBjb25zdHJ1Y3RvciBvZiB0eXBlZCBhcnJheXMuXG4gICAgICBpZiAoQ3RvciBpbnN0YW5jZW9mIEN0b3IpIHtcbiAgICAgICAgQ3RvciA9IGN0b3JCeVRhZ1t0YWddO1xuICAgICAgfVxuICAgICAgdmFyIGJ1ZmZlciA9IG9iamVjdC5idWZmZXI7XG4gICAgICByZXR1cm4gbmV3IEN0b3IoaXNEZWVwID8gYnVmZmVyQ2xvbmUoYnVmZmVyKSA6IGJ1ZmZlciwgb2JqZWN0LmJ5dGVPZmZzZXQsIG9iamVjdC5sZW5ndGgpO1xuXG4gICAgY2FzZSBudW1iZXJUYWc6XG4gICAgY2FzZSBzdHJpbmdUYWc6XG4gICAgICByZXR1cm4gbmV3IEN0b3Iob2JqZWN0KTtcblxuICAgIGNhc2UgcmVnZXhwVGFnOlxuICAgICAgdmFyIHJlc3VsdCA9IG5ldyBDdG9yKG9iamVjdC5zb3VyY2UsIHJlRmxhZ3MuZXhlYyhvYmplY3QpKTtcbiAgICAgIHJlc3VsdC5sYXN0SW5kZXggPSBvYmplY3QubGFzdEluZGV4O1xuICB9XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gaW5pdENsb25lQnlUYWc7XG4iXX0= 19673 },{"./bufferClone":99}],122:[function(require,module,exports){ 19674 /** 19675 * Initializes an object clone. 19676 * 19677 * @private 19678 * @param {Object} object The object to clone. 19679 * @returns {Object} Returns the initialized clone. 19680 */ 19681 function initCloneObject(object) { 19682 var Ctor = object.constructor; 19683 if (!(typeof Ctor == 'function' && Ctor instanceof Ctor)) { 19684 Ctor = Object; 19685 } 19686 return new Ctor; 19687 } 19688 19689 module.exports = initCloneObject; 19690 19691 },{}],123:[function(require,module,exports){ 19692 var getLength = require('./getLength'), 19693 isLength = require('./isLength'); 19694 19695 /** 19696 * Checks if `value` is array-like. 19697 * 19698 * @private 19699 * @param {*} value The value to check. 19700 * @returns {boolean} Returns `true` if `value` is array-like, else `false`. 19701 */ 19702 function isArrayLike(value) { 19703 return value != null && isLength(getLength(value)); 19704 } 19705 19706 module.exports = isArrayLike; 19707 19708 },{"./getLength":116,"./isLength":129}],124:[function(require,module,exports){ 19709 /** 19710 * Checks if `value` is a host object in IE < 9. 19711 * 19712 * @private 19713 * @param {*} value The value to check. 19714 * @returns {boolean} Returns `true` if `value` is a host object, else `false`. 19715 */ 19716 var isHostObject = (function() { 19717 try { 19718 Object({ 'toString': 0 } + ''); 19719 } catch(e) { 19720 return function() { return false; }; 19721 } 19722 return function(value) { 19723 // IE < 9 presents many host objects as `Object` objects that can coerce 19724 // to strings despite having improperly defined `toString` methods. 19725 return typeof value.toString != 'function' && typeof (value + '') == 'string'; 19726 }; 19727 }()); 19728 19729 module.exports = isHostObject; 19730 19731 },{}],125:[function(require,module,exports){ 19732 /** Used to detect unsigned integer values. */ 19733 var reIsUint = /^\d+$/; 19734 19735 /** 19736 * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) 19737 * of an array-like value. 19738 */ 19739 var MAX_SAFE_INTEGER = 9007199254740991; 19740 19741 /** 19742 * Checks if `value` is a valid array-like index. 19743 * 19744 * @private 19745 * @param {*} value The value to check. 19746 * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. 19747 * @returns {boolean} Returns `true` if `value` is a valid index, else `false`. 19748 */ 19749 function isIndex(value, length) { 19750 value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; 19751 length = length == null ? MAX_SAFE_INTEGER : length; 19752 return value > -1 && value % 1 == 0 && value < length; 19753 } 19754 19755 module.exports = isIndex; 19756 19757 },{}],126:[function(require,module,exports){ 19758 var isArrayLike = require('./isArrayLike'), 19759 isIndex = require('./isIndex'), 19760 isObject = require('../lang/isObject'); 19761 19762 /** 19763 * Checks if the provided arguments are from an iteratee call. 19764 * 19765 * @private 19766 * @param {*} value The potential iteratee value argument. 19767 * @param {*} index The potential iteratee index or key argument. 19768 * @param {*} object The potential iteratee object argument. 19769 * @returns {boolean} Returns `true` if the arguments are from an iteratee call, else `false`. 19770 */ 19771 function isIterateeCall(value, index, object) { 19772 if (!isObject(object)) { 19773 return false; 19774 } 19775 var type = typeof index; 19776 if (type == 'number' 19777 ? (isArrayLike(object) && isIndex(index, object.length)) 19778 : (type == 'string' && index in object)) { 19779 var other = object[index]; 19780 return value === value ? (value === other) : (other !== other); 19781 } 19782 return false; 19783 } 19784 19785 module.exports = isIterateeCall; 19786 19787 },{"../lang/isObject":148,"./isArrayLike":123,"./isIndex":125}],127:[function(require,module,exports){ 19788 var isArray = require('../lang/isArray'), 19789 toObject = require('./toObject'); 19790 19791 /** Used to match property names within property paths. */ 19792 var reIsDeepProp = /\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\n\\]|\\.)*?\1)\]/, 19793 reIsPlainProp = /^\w*$/; 19794 19795 /** 19796 * Checks if `value` is a property name and not a property path. 19797 * 19798 * @private 19799 * @param {*} value The value to check. 19800 * @param {Object} [object] The object to query keys on. 19801 * @returns {boolean} Returns `true` if `value` is a property name, else `false`. 19802 */ 19803 function isKey(value, object) { 19804 var type = typeof value; 19805 if ((type == 'string' && reIsPlainProp.test(value)) || type == 'number') { 19806 return true; 19807 } 19808 if (isArray(value)) { 19809 return false; 19810 } 19811 var result = !reIsDeepProp.test(value); 19812 return result || (object != null && value in toObject(object)); 19813 } 19814 19815 module.exports = isKey; 19816 19817 },{"../lang/isArray":144,"./toObject":139}],128:[function(require,module,exports){ 19818 var LazyWrapper = require('./LazyWrapper'), 19819 getData = require('./getData'), 19820 getFuncName = require('./getFuncName'), 19821 lodash = require('../chain/lodash'); 19822 19823 /** 19824 * Checks if `func` has a lazy counterpart. 19825 * 19826 * @private 19827 * @param {Function} func The function to check. 19828 * @returns {boolean} Returns `true` if `func` has a lazy counterpart, else `false`. 19829 */ 19830 function isLaziable(func) { 19831 var funcName = getFuncName(func), 19832 other = lodash[funcName]; 19833 19834 if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) { 19835 return false; 19836 } 19837 if (func === other) { 19838 return true; 19839 } 19840 var data = getData(other); 19841 return !!data && func === data[0]; 19842 } 19843 19844 module.exports = isLaziable; 19845 19846 },{"../chain/lodash":55,"./LazyWrapper":64,"./getData":114,"./getFuncName":115}],129:[function(require,module,exports){ 19847 /** 19848 * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) 19849 * of an array-like value. 19850 */ 19851 var MAX_SAFE_INTEGER = 9007199254740991; 19852 19853 /** 19854 * Checks if `value` is a valid array-like length. 19855 * 19856 * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). 19857 * 19858 * @private 19859 * @param {*} value The value to check. 19860 * @returns {boolean} Returns `true` if `value` is a valid length, else `false`. 19861 */ 19862 function isLength(value) { 19863 return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; 19864 } 19865 19866 module.exports = isLength; 19867 19868 },{}],130:[function(require,module,exports){ 19869 /** 19870 * Checks if `value` is object-like. 19871 * 19872 * @private 19873 * @param {*} value The value to check. 19874 * @returns {boolean} Returns `true` if `value` is object-like, else `false`. 19875 */ 19876 function isObjectLike(value) { 19877 return !!value && typeof value == 'object'; 19878 } 19879 19880 module.exports = isObjectLike; 19881 19882 },{}],131:[function(require,module,exports){ 19883 var isObject = require('../lang/isObject'); 19884 19885 /** 19886 * Checks if `value` is suitable for strict equality comparisons, i.e. `===`. 19887 * 19888 * @private 19889 * @param {*} value The value to check. 19890 * @returns {boolean} Returns `true` if `value` if suitable for strict 19891 * equality comparisons, else `false`. 19892 */ 19893 function isStrictComparable(value) { 19894 return value === value && !isObject(value); 19895 } 19896 19897 module.exports = isStrictComparable; 19898 19899 },{"../lang/isObject":148}],132:[function(require,module,exports){ 19900 var arrayCopy = require('./arrayCopy'), 19901 composeArgs = require('./composeArgs'), 19902 composeArgsRight = require('./composeArgsRight'), 19903 replaceHolders = require('./replaceHolders'); 19904 19905 /** Used to compose bitmasks for wrapper metadata. */ 19906 var BIND_FLAG = 1, 19907 CURRY_BOUND_FLAG = 4, 19908 CURRY_FLAG = 8, 19909 ARY_FLAG = 128, 19910 REARG_FLAG = 256; 19911 19912 /** Used as the internal argument placeholder. */ 19913 var PLACEHOLDER = '__lodash_placeholder__'; 19914 19915 /* Native method references for those with the same name as other `lodash` methods. */ 19916 var nativeMin = Math.min; 19917 19918 /** 19919 * Merges the function metadata of `source` into `data`. 19920 * 19921 * Merging metadata reduces the number of wrappers required to invoke a function. 19922 * This is possible because methods like `_.bind`, `_.curry`, and `_.partial` 19923 * may be applied regardless of execution order. Methods like `_.ary` and `_.rearg` 19924 * augment function arguments, making the order in which they are executed important, 19925 * preventing the merging of metadata. However, we make an exception for a safe 19926 * common case where curried functions have `_.ary` and or `_.rearg` applied. 19927 * 19928 * @private 19929 * @param {Array} data The destination metadata. 19930 * @param {Array} source The source metadata. 19931 * @returns {Array} Returns `data`. 19932 */ 19933 function mergeData(data, source) { 19934 var bitmask = data[1], 19935 srcBitmask = source[1], 19936 newBitmask = bitmask | srcBitmask, 19937 isCommon = newBitmask < ARY_FLAG; 19938 19939 var isCombo = 19940 (srcBitmask == ARY_FLAG && bitmask == CURRY_FLAG) || 19941 (srcBitmask == ARY_FLAG && bitmask == REARG_FLAG && data[7].length <= source[8]) || 19942 (srcBitmask == (ARY_FLAG | REARG_FLAG) && bitmask == CURRY_FLAG); 19943 19944 // Exit early if metadata can't be merged. 19945 if (!(isCommon || isCombo)) { 19946 return data; 19947 } 19948 // Use source `thisArg` if available. 19949 if (srcBitmask & BIND_FLAG) { 19950 data[2] = source[2]; 19951 // Set when currying a bound function. 19952 newBitmask |= (bitmask & BIND_FLAG) ? 0 : CURRY_BOUND_FLAG; 19953 } 19954 // Compose partial arguments. 19955 var value = source[3]; 19956 if (value) { 19957 var partials = data[3]; 19958 data[3] = partials ? composeArgs(partials, value, source[4]) : arrayCopy(value); 19959 data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : arrayCopy(source[4]); 19960 } 19961 // Compose partial right arguments. 19962 value = source[5]; 19963 if (value) { 19964 partials = data[5]; 19965 data[5] = partials ? composeArgsRight(partials, value, source[6]) : arrayCopy(value); 19966 data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : arrayCopy(source[6]); 19967 } 19968 // Use source `argPos` if available. 19969 value = source[7]; 19970 if (value) { 19971 data[7] = arrayCopy(value); 19972 } 19973 // Use source `ary` if it's smaller. 19974 if (srcBitmask & ARY_FLAG) { 19975 data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]); 19976 } 19977 // Use source `arity` if one is not provided. 19978 if (data[9] == null) { 19979 data[9] = source[9]; 19980 } 19981 // Use source `func` and merge bitmasks. 19982 data[0] = source[0]; 19983 data[1] = newBitmask; 19984 19985 return data; 19986 } 19987 19988 module.exports = mergeData; 19989 19990 },{"./arrayCopy":66,"./composeArgs":100,"./composeArgsRight":101,"./replaceHolders":136}],133:[function(require,module,exports){ 19991 (function (global){ 19992 var getNative = require('./getNative'); 19993 19994 /** Native method references. */ 19995 var WeakMap = getNative(global, 'WeakMap'); 19996 19997 /** Used to store function metadata. */ 19998 var metaMap = WeakMap && new WeakMap; 19999 20000 module.exports = metaMap; 20001 20002 }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) 20003 //# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL21ldGFNYXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgZ2V0TmF0aXZlID0gcmVxdWlyZSgnLi9nZXROYXRpdmUnKTtcblxuLyoqIE5hdGl2ZSBtZXRob2QgcmVmZXJlbmNlcy4gKi9cbnZhciBXZWFrTWFwID0gZ2V0TmF0aXZlKGdsb2JhbCwgJ1dlYWtNYXAnKTtcblxuLyoqIFVzZWQgdG8gc3RvcmUgZnVuY3Rpb24gbWV0YWRhdGEuICovXG52YXIgbWV0YU1hcCA9IFdlYWtNYXAgJiYgbmV3IFdlYWtNYXA7XG5cbm1vZHVsZS5leHBvcnRzID0gbWV0YU1hcDtcbiJdfQ== 20004 },{"./getNative":118}],134:[function(require,module,exports){ 20005 /** Used to lookup unminified function names. */ 20006 var realNames = {}; 20007 20008 module.exports = realNames; 20009 20010 },{}],135:[function(require,module,exports){ 20011 var arrayCopy = require('./arrayCopy'), 20012 isIndex = require('./isIndex'); 20013 20014 /* Native method references for those with the same name as other `lodash` methods. */ 20015 var nativeMin = Math.min; 20016 20017 /** 20018 * Reorder `array` according to the specified indexes where the element at 20019 * the first index is assigned as the first element, the element at 20020 * the second index is assigned as the second element, and so on. 20021 * 20022 * @private 20023 * @param {Array} array The array to reorder. 20024 * @param {Array} indexes The arranged array indexes. 20025 * @returns {Array} Returns `array`. 20026 */ 20027 function reorder(array, indexes) { 20028 var arrLength = array.length, 20029 length = nativeMin(indexes.length, arrLength), 20030 oldArray = arrayCopy(array); 20031 20032 while (length--) { 20033 var index = indexes[length]; 20034 array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined; 20035 } 20036 return array; 20037 } 20038 20039 module.exports = reorder; 20040 20041 },{"./arrayCopy":66,"./isIndex":125}],136:[function(require,module,exports){ 20042 /** Used as the internal argument placeholder. */ 20043 var PLACEHOLDER = '__lodash_placeholder__'; 20044 20045 /** 20046 * Replaces all `placeholder` elements in `array` with an internal placeholder 20047 * and returns an array of their indexes. 20048 * 20049 * @private 20050 * @param {Array} array The array to modify. 20051 * @param {*} placeholder The placeholder to replace. 20052 * @returns {Array} Returns the new array of placeholder indexes. 20053 */ 20054 function replaceHolders(array, placeholder) { 20055 var index = -1, 20056 length = array.length, 20057 resIndex = -1, 20058 result = []; 20059 20060 while (++index < length) { 20061 if (array[index] === placeholder) { 20062 array[index] = PLACEHOLDER; 20063 result[++resIndex] = index; 20064 } 20065 } 20066 return result; 20067 } 20068 20069 module.exports = replaceHolders; 20070 20071 },{}],137:[function(require,module,exports){ 20072 var baseSetData = require('./baseSetData'), 20073 now = require('../date/now'); 20074 20075 /** Used to detect when a function becomes hot. */ 20076 var HOT_COUNT = 150, 20077 HOT_SPAN = 16; 20078 20079 /** 20080 * Sets metadata for `func`. 20081 * 20082 * **Note:** If this function becomes hot, i.e. is invoked a lot in a short 20083 * period of time, it will trip its breaker and transition to an identity function 20084 * to avoid garbage collection pauses in V8. See [V8 issue 2070](https://code.google.com/p/v8/issues/detail?id=2070) 20085 * for more details. 20086 * 20087 * @private 20088 * @param {Function} func The function to associate metadata with. 20089 * @param {*} data The metadata. 20090 * @returns {Function} Returns `func`. 20091 */ 20092 var setData = (function() { 20093 var count = 0, 20094 lastCalled = 0; 20095 20096 return function(key, value) { 20097 var stamp = now(), 20098 remaining = HOT_SPAN - (stamp - lastCalled); 20099 20100 lastCalled = stamp; 20101 if (remaining > 0) { 20102 if (++count >= HOT_COUNT) { 20103 return key; 20104 } 20105 } else { 20106 count = 0; 20107 } 20108 return baseSetData(key, value); 20109 }; 20110 }()); 20111 20112 module.exports = setData; 20113 20114 },{"../date/now":61,"./baseSetData":92}],138:[function(require,module,exports){ 20115 var isArguments = require('../lang/isArguments'), 20116 isArray = require('../lang/isArray'), 20117 isIndex = require('./isIndex'), 20118 isLength = require('./isLength'), 20119 isString = require('../lang/isString'), 20120 keysIn = require('../object/keysIn'); 20121 20122 /** Used for native method references. */ 20123 var objectProto = Object.prototype; 20124 20125 /** Used to check objects for own properties. */ 20126 var hasOwnProperty = objectProto.hasOwnProperty; 20127 20128 /** 20129 * A fallback implementation of `Object.keys` which creates an array of the 20130 * own enumerable property names of `object`. 20131 * 20132 * @private 20133 * @param {Object} object The object to query. 20134 * @returns {Array} Returns the array of property names. 20135 */ 20136 function shimKeys(object) { 20137 var props = keysIn(object), 20138 propsLength = props.length, 20139 length = propsLength && object.length; 20140 20141 var allowIndexes = !!length && isLength(length) && 20142 (isArray(object) || isArguments(object) || isString(object)); 20143 20144 var index = -1, 20145 result = []; 20146 20147 while (++index < propsLength) { 20148 var key = props[index]; 20149 if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) { 20150 result.push(key); 20151 } 20152 } 20153 return result; 20154 } 20155 20156 module.exports = shimKeys; 20157 20158 },{"../lang/isArguments":143,"../lang/isArray":144,"../lang/isString":150,"../object/keysIn":154,"./isIndex":125,"./isLength":129}],139:[function(require,module,exports){ 20159 var isObject = require('../lang/isObject'), 20160 isString = require('../lang/isString'), 20161 support = require('../support'); 20162 20163 /** 20164 * Converts `value` to an object if it's not one. 20165 * 20166 * @private 20167 * @param {*} value The value to process. 20168 * @returns {Object} Returns the object. 20169 */ 20170 function toObject(value) { 20171 if (support.unindexedChars && isString(value)) { 20172 var index = -1, 20173 length = value.length, 20174 result = Object(value); 20175 20176 while (++index < length) { 20177 result[index] = value.charAt(index); 20178 } 20179 return result; 20180 } 20181 return isObject(value) ? value : Object(value); 20182 } 20183 20184 module.exports = toObject; 20185 20186 },{"../lang/isObject":148,"../lang/isString":150,"../support":157}],140:[function(require,module,exports){ 20187 var baseToString = require('./baseToString'), 20188 isArray = require('../lang/isArray'); 20189 20190 /** Used to match property names within property paths. */ 20191 var rePropName = /[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\n\\]|\\.)*?)\2)\]/g; 20192 20193 /** Used to match backslashes in property paths. */ 20194 var reEscapeChar = /\\(\\)?/g; 20195 20196 /** 20197 * Converts `value` to property path array if it's not one. 20198 * 20199 * @private 20200 * @param {*} value The value to process. 20201 * @returns {Array} Returns the property path array. 20202 */ 20203 function toPath(value) { 20204 if (isArray(value)) { 20205 return value; 20206 } 20207 var result = []; 20208 baseToString(value).replace(rePropName, function(match, number, quote, string) { 20209 result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match)); 20210 }); 20211 return result; 20212 } 20213 20214 module.exports = toPath; 20215 20216 },{"../lang/isArray":144,"./baseToString":94}],141:[function(require,module,exports){ 20217 var LazyWrapper = require('./LazyWrapper'), 20218 LodashWrapper = require('./LodashWrapper'), 20219 arrayCopy = require('./arrayCopy'); 20220 20221 /** 20222 * Creates a clone of `wrapper`. 20223 * 20224 * @private 20225 * @param {Object} wrapper The wrapper to clone. 20226 * @returns {Object} Returns the cloned wrapper. 20227 */ 20228 function wrapperClone(wrapper) { 20229 return wrapper instanceof LazyWrapper 20230 ? wrapper.clone() 20231 : new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__, arrayCopy(wrapper.__actions__)); 20232 } 20233 20234 module.exports = wrapperClone; 20235 20236 },{"./LazyWrapper":64,"./LodashWrapper":65,"./arrayCopy":66}],142:[function(require,module,exports){ 20237 var baseClone = require('../internal/baseClone'), 20238 bindCallback = require('../internal/bindCallback'); 20239 20240 /** 20241 * Creates a deep clone of `value`. If `customizer` is provided it's invoked 20242 * to produce the cloned values. If `customizer` returns `undefined` cloning 20243 * is handled by the method instead. The `customizer` is bound to `thisArg` 20244 * and invoked with up to three argument; (value [, index|key, object]). 20245 * 20246 * **Note:** This method is loosely based on the 20247 * [structured clone algorithm](http://www.w3.org/TR/html5/infrastructure.html#internal-structured-cloning-algorithm). 20248 * The enumerable properties of `arguments` objects and objects created by 20249 * constructors other than `Object` are cloned to plain `Object` objects. An 20250 * empty object is returned for uncloneable values such as functions, DOM nodes, 20251 * Maps, Sets, and WeakMaps. 20252 * 20253 * @static 20254 * @memberOf _ 20255 * @category Lang 20256 * @param {*} value The value to deep clone. 20257 * @param {Function} [customizer] The function to customize cloning values. 20258 * @param {*} [thisArg] The `this` binding of `customizer`. 20259 * @returns {*} Returns the deep cloned value. 20260 * @example 20261 * 20262 * var users = [ 20263 * { 'user': 'barney' }, 20264 * { 'user': 'fred' } 20265 * ]; 20266 * 20267 * var deep = _.cloneDeep(users); 20268 * deep[0] === users[0]; 20269 * // => false 20270 * 20271 * // using a customizer callback 20272 * var el = _.cloneDeep(document.body, function(value) { 20273 * if (_.isElement(value)) { 20274 * return value.cloneNode(true); 20275 * } 20276 * }); 20277 * 20278 * el === document.body 20279 * // => false 20280 * el.nodeName 20281 * // => BODY 20282 * el.childNodes.length; 20283 * // => 20 20284 */ 20285 function cloneDeep(value, customizer, thisArg) { 20286 return typeof customizer == 'function' 20287 ? baseClone(value, true, bindCallback(customizer, thisArg, 3)) 20288 : baseClone(value, true); 20289 } 20290 20291 module.exports = cloneDeep; 20292 20293 },{"../internal/baseClone":72,"../internal/bindCallback":98}],143:[function(require,module,exports){ 20294 var isArrayLike = require('../internal/isArrayLike'), 20295 isObjectLike = require('../internal/isObjectLike'); 20296 20297 /** Used for native method references. */ 20298 var objectProto = Object.prototype; 20299 20300 /** Used to check objects for own properties. */ 20301 var hasOwnProperty = objectProto.hasOwnProperty; 20302 20303 /** Native method references. */ 20304 var propertyIsEnumerable = objectProto.propertyIsEnumerable; 20305 20306 /** 20307 * Checks if `value` is classified as an `arguments` object. 20308 * 20309 * @static 20310 * @memberOf _ 20311 * @category Lang 20312 * @param {*} value The value to check. 20313 * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. 20314 * @example 20315 * 20316 * _.isArguments(function() { return arguments; }()); 20317 * // => true 20318 * 20319 * _.isArguments([1, 2, 3]); 20320 * // => false 20321 */ 20322 function isArguments(value) { 20323 return isObjectLike(value) && isArrayLike(value) && 20324 hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee'); 20325 } 20326 20327 module.exports = isArguments; 20328 20329 },{"../internal/isArrayLike":123,"../internal/isObjectLike":130}],144:[function(require,module,exports){ 20330 var getNative = require('../internal/getNative'), 20331 isLength = require('../internal/isLength'), 20332 isObjectLike = require('../internal/isObjectLike'); 20333 20334 /** `Object#toString` result references. */ 20335 var arrayTag = '[object Array]'; 20336 20337 /** Used for native method references. */ 20338 var objectProto = Object.prototype; 20339 20340 /** 20341 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20342 * of values. 20343 */ 20344 var objToString = objectProto.toString; 20345 20346 /* Native method references for those with the same name as other `lodash` methods. */ 20347 var nativeIsArray = getNative(Array, 'isArray'); 20348 20349 /** 20350 * Checks if `value` is classified as an `Array` object. 20351 * 20352 * @static 20353 * @memberOf _ 20354 * @category Lang 20355 * @param {*} value The value to check. 20356 * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. 20357 * @example 20358 * 20359 * _.isArray([1, 2, 3]); 20360 * // => true 20361 * 20362 * _.isArray(function() { return arguments; }()); 20363 * // => false 20364 */ 20365 var isArray = nativeIsArray || function(value) { 20366 return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag; 20367 }; 20368 20369 module.exports = isArray; 20370 20371 },{"../internal/getNative":118,"../internal/isLength":129,"../internal/isObjectLike":130}],145:[function(require,module,exports){ 20372 var isArguments = require('./isArguments'), 20373 isArray = require('./isArray'), 20374 isArrayLike = require('../internal/isArrayLike'), 20375 isFunction = require('./isFunction'), 20376 isObjectLike = require('../internal/isObjectLike'), 20377 isString = require('./isString'), 20378 keys = require('../object/keys'); 20379 20380 /** 20381 * Checks if `value` is empty. A value is considered empty unless it's an 20382 * `arguments` object, array, string, or jQuery-like collection with a length 20383 * greater than `0` or an object with own enumerable properties. 20384 * 20385 * @static 20386 * @memberOf _ 20387 * @category Lang 20388 * @param {Array|Object|string} value The value to inspect. 20389 * @returns {boolean} Returns `true` if `value` is empty, else `false`. 20390 * @example 20391 * 20392 * _.isEmpty(null); 20393 * // => true 20394 * 20395 * _.isEmpty(true); 20396 * // => true 20397 * 20398 * _.isEmpty(1); 20399 * // => true 20400 * 20401 * _.isEmpty([1, 2, 3]); 20402 * // => false 20403 * 20404 * _.isEmpty({ 'a': 1 }); 20405 * // => false 20406 */ 20407 function isEmpty(value) { 20408 if (value == null) { 20409 return true; 20410 } 20411 if (isArrayLike(value) && (isArray(value) || isString(value) || isArguments(value) || 20412 (isObjectLike(value) && isFunction(value.splice)))) { 20413 return !value.length; 20414 } 20415 return !keys(value).length; 20416 } 20417 20418 module.exports = isEmpty; 20419 20420 },{"../internal/isArrayLike":123,"../internal/isObjectLike":130,"../object/keys":153,"./isArguments":143,"./isArray":144,"./isFunction":146,"./isString":150}],146:[function(require,module,exports){ 20421 var isObject = require('./isObject'); 20422 20423 /** `Object#toString` result references. */ 20424 var funcTag = '[object Function]'; 20425 20426 /** Used for native method references. */ 20427 var objectProto = Object.prototype; 20428 20429 /** 20430 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20431 * of values. 20432 */ 20433 var objToString = objectProto.toString; 20434 20435 /** 20436 * Checks if `value` is classified as a `Function` object. 20437 * 20438 * @static 20439 * @memberOf _ 20440 * @category Lang 20441 * @param {*} value The value to check. 20442 * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. 20443 * @example 20444 * 20445 * _.isFunction(_); 20446 * // => true 20447 * 20448 * _.isFunction(/abc/); 20449 * // => false 20450 */ 20451 function isFunction(value) { 20452 // The use of `Object#toString` avoids issues with the `typeof` operator 20453 // in older versions of Chrome and Safari which return 'function' for regexes 20454 // and Safari 8 which returns 'object' for typed array constructors. 20455 return isObject(value) && objToString.call(value) == funcTag; 20456 } 20457 20458 module.exports = isFunction; 20459 20460 },{"./isObject":148}],147:[function(require,module,exports){ 20461 var isFunction = require('./isFunction'), 20462 isHostObject = require('../internal/isHostObject'), 20463 isObjectLike = require('../internal/isObjectLike'); 20464 20465 /** Used to detect host constructors (Safari > 5). */ 20466 var reIsHostCtor = /^\[object .+?Constructor\]$/; 20467 20468 /** Used for native method references. */ 20469 var objectProto = Object.prototype; 20470 20471 /** Used to resolve the decompiled source of functions. */ 20472 var fnToString = Function.prototype.toString; 20473 20474 /** Used to check objects for own properties. */ 20475 var hasOwnProperty = objectProto.hasOwnProperty; 20476 20477 /** Used to detect if a method is native. */ 20478 var reIsNative = RegExp('^' + 20479 fnToString.call(hasOwnProperty).replace(/[\\^$.*+?()[\]{}|]/g, '\\$&') 20480 .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$' 20481 ); 20482 20483 /** 20484 * Checks if `value` is a native function. 20485 * 20486 * @static 20487 * @memberOf _ 20488 * @category Lang 20489 * @param {*} value The value to check. 20490 * @returns {boolean} Returns `true` if `value` is a native function, else `false`. 20491 * @example 20492 * 20493 * _.isNative(Array.prototype.push); 20494 * // => true 20495 * 20496 * _.isNative(_); 20497 * // => false 20498 */ 20499 function isNative(value) { 20500 if (value == null) { 20501 return false; 20502 } 20503 if (isFunction(value)) { 20504 return reIsNative.test(fnToString.call(value)); 20505 } 20506 return isObjectLike(value) && (isHostObject(value) ? reIsNative : reIsHostCtor).test(value); 20507 } 20508 20509 module.exports = isNative; 20510 20511 },{"../internal/isHostObject":124,"../internal/isObjectLike":130,"./isFunction":146}],148:[function(require,module,exports){ 20512 /** 20513 * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. 20514 * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) 20515 * 20516 * @static 20517 * @memberOf _ 20518 * @category Lang 20519 * @param {*} value The value to check. 20520 * @returns {boolean} Returns `true` if `value` is an object, else `false`. 20521 * @example 20522 * 20523 * _.isObject({}); 20524 * // => true 20525 * 20526 * _.isObject([1, 2, 3]); 20527 * // => true 20528 * 20529 * _.isObject(1); 20530 * // => false 20531 */ 20532 function isObject(value) { 20533 // Avoid a V8 JIT bug in Chrome 19-20. 20534 // See https://code.google.com/p/v8/issues/detail?id=2291 for more details. 20535 var type = typeof value; 20536 return !!value && (type == 'object' || type == 'function'); 20537 } 20538 20539 module.exports = isObject; 20540 20541 },{}],149:[function(require,module,exports){ 20542 var baseForIn = require('../internal/baseForIn'), 20543 isArguments = require('./isArguments'), 20544 isHostObject = require('../internal/isHostObject'), 20545 isObjectLike = require('../internal/isObjectLike'), 20546 support = require('../support'); 20547 20548 /** `Object#toString` result references. */ 20549 var objectTag = '[object Object]'; 20550 20551 /** Used for native method references. */ 20552 var objectProto = Object.prototype; 20553 20554 /** Used to check objects for own properties. */ 20555 var hasOwnProperty = objectProto.hasOwnProperty; 20556 20557 /** 20558 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20559 * of values. 20560 */ 20561 var objToString = objectProto.toString; 20562 20563 /** 20564 * Checks if `value` is a plain object, that is, an object created by the 20565 * `Object` constructor or one with a `[[Prototype]]` of `null`. 20566 * 20567 * **Note:** This method assumes objects created by the `Object` constructor 20568 * have no inherited enumerable properties. 20569 * 20570 * @static 20571 * @memberOf _ 20572 * @category Lang 20573 * @param {*} value The value to check. 20574 * @returns {boolean} Returns `true` if `value` is a plain object, else `false`. 20575 * @example 20576 * 20577 * function Foo() { 20578 * this.a = 1; 20579 * } 20580 * 20581 * _.isPlainObject(new Foo); 20582 * // => false 20583 * 20584 * _.isPlainObject([1, 2, 3]); 20585 * // => false 20586 * 20587 * _.isPlainObject({ 'x': 0, 'y': 0 }); 20588 * // => true 20589 * 20590 * _.isPlainObject(Object.create(null)); 20591 * // => true 20592 */ 20593 function isPlainObject(value) { 20594 var Ctor; 20595 20596 // Exit early for non `Object` objects. 20597 if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isHostObject(value) && !isArguments(value)) || 20598 (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) { 20599 return false; 20600 } 20601 // IE < 9 iterates inherited properties before own properties. If the first 20602 // iterated property is an object's own property then there are no inherited 20603 // enumerable properties. 20604 var result; 20605 if (support.ownLast) { 20606 baseForIn(value, function(subValue, key, object) { 20607 result = hasOwnProperty.call(object, key); 20608 return false; 20609 }); 20610 return result !== false; 20611 } 20612 // In most environments an object's own properties are iterated before 20613 // its inherited properties. If the last iterated property is an object's 20614 // own property then there are no inherited enumerable properties. 20615 baseForIn(value, function(subValue, key) { 20616 result = key; 20617 }); 20618 return result === undefined || hasOwnProperty.call(value, result); 20619 } 20620 20621 module.exports = isPlainObject; 20622 20623 },{"../internal/baseForIn":79,"../internal/isHostObject":124,"../internal/isObjectLike":130,"../support":157,"./isArguments":143}],150:[function(require,module,exports){ 20624 var isObjectLike = require('../internal/isObjectLike'); 20625 20626 /** `Object#toString` result references. */ 20627 var stringTag = '[object String]'; 20628 20629 /** Used for native method references. */ 20630 var objectProto = Object.prototype; 20631 20632 /** 20633 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20634 * of values. 20635 */ 20636 var objToString = objectProto.toString; 20637 20638 /** 20639 * Checks if `value` is classified as a `String` primitive or object. 20640 * 20641 * @static 20642 * @memberOf _ 20643 * @category Lang 20644 * @param {*} value The value to check. 20645 * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. 20646 * @example 20647 * 20648 * _.isString('abc'); 20649 * // => true 20650 * 20651 * _.isString(1); 20652 * // => false 20653 */ 20654 function isString(value) { 20655 return typeof value == 'string' || (isObjectLike(value) && objToString.call(value) == stringTag); 20656 } 20657 20658 module.exports = isString; 20659 20660 },{"../internal/isObjectLike":130}],151:[function(require,module,exports){ 20661 var isLength = require('../internal/isLength'), 20662 isObjectLike = require('../internal/isObjectLike'); 20663 20664 /** `Object#toString` result references. */ 20665 var argsTag = '[object Arguments]', 20666 arrayTag = '[object Array]', 20667 boolTag = '[object Boolean]', 20668 dateTag = '[object Date]', 20669 errorTag = '[object Error]', 20670 funcTag = '[object Function]', 20671 mapTag = '[object Map]', 20672 numberTag = '[object Number]', 20673 objectTag = '[object Object]', 20674 regexpTag = '[object RegExp]', 20675 setTag = '[object Set]', 20676 stringTag = '[object String]', 20677 weakMapTag = '[object WeakMap]'; 20678 20679 var arrayBufferTag = '[object ArrayBuffer]', 20680 float32Tag = '[object Float32Array]', 20681 float64Tag = '[object Float64Array]', 20682 int8Tag = '[object Int8Array]', 20683 int16Tag = '[object Int16Array]', 20684 int32Tag = '[object Int32Array]', 20685 uint8Tag = '[object Uint8Array]', 20686 uint8ClampedTag = '[object Uint8ClampedArray]', 20687 uint16Tag = '[object Uint16Array]', 20688 uint32Tag = '[object Uint32Array]'; 20689 20690 /** Used to identify `toStringTag` values of typed arrays. */ 20691 var typedArrayTags = {}; 20692 typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = 20693 typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = 20694 typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = 20695 typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = 20696 typedArrayTags[uint32Tag] = true; 20697 typedArrayTags[argsTag] = typedArrayTags[arrayTag] = 20698 typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = 20699 typedArrayTags[dateTag] = typedArrayTags[errorTag] = 20700 typedArrayTags[funcTag] = typedArrayTags[mapTag] = 20701 typedArrayTags[numberTag] = typedArrayTags[objectTag] = 20702 typedArrayTags[regexpTag] = typedArrayTags[setTag] = 20703 typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; 20704 20705 /** Used for native method references. */ 20706 var objectProto = Object.prototype; 20707 20708 /** 20709 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20710 * of values. 20711 */ 20712 var objToString = objectProto.toString; 20713 20714 /** 20715 * Checks if `value` is classified as a typed array. 20716 * 20717 * @static 20718 * @memberOf _ 20719 * @category Lang 20720 * @param {*} value The value to check. 20721 * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. 20722 * @example 20723 * 20724 * _.isTypedArray(new Uint8Array); 20725 * // => true 20726 * 20727 * _.isTypedArray([]); 20728 * // => false 20729 */ 20730 function isTypedArray(value) { 20731 return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)]; 20732 } 20733 20734 module.exports = isTypedArray; 20735 20736 },{"../internal/isLength":129,"../internal/isObjectLike":130}],152:[function(require,module,exports){ 20737 /** 20738 * Checks if `value` is `undefined`. 20739 * 20740 * @static 20741 * @memberOf _ 20742 * @category Lang 20743 * @param {*} value The value to check. 20744 * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`. 20745 * @example 20746 * 20747 * _.isUndefined(void 0); 20748 * // => true 20749 * 20750 * _.isUndefined(null); 20751 * // => false 20752 */ 20753 function isUndefined(value) { 20754 return value === undefined; 20755 } 20756 20757 module.exports = isUndefined; 20758 20759 },{}],153:[function(require,module,exports){ 20760 var getNative = require('../internal/getNative'), 20761 isArrayLike = require('../internal/isArrayLike'), 20762 isObject = require('../lang/isObject'), 20763 shimKeys = require('../internal/shimKeys'), 20764 support = require('../support'); 20765 20766 /* Native method references for those with the same name as other `lodash` methods. */ 20767 var nativeKeys = getNative(Object, 'keys'); 20768 20769 /** 20770 * Creates an array of the own enumerable property names of `object`. 20771 * 20772 * **Note:** Non-object values are coerced to objects. See the 20773 * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) 20774 * for more details. 20775 * 20776 * @static 20777 * @memberOf _ 20778 * @category Object 20779 * @param {Object} object The object to query. 20780 * @returns {Array} Returns the array of property names. 20781 * @example 20782 * 20783 * function Foo() { 20784 * this.a = 1; 20785 * this.b = 2; 20786 * } 20787 * 20788 * Foo.prototype.c = 3; 20789 * 20790 * _.keys(new Foo); 20791 * // => ['a', 'b'] (iteration order is not guaranteed) 20792 * 20793 * _.keys('hi'); 20794 * // => ['0', '1'] 20795 */ 20796 var keys = !nativeKeys ? shimKeys : function(object) { 20797 var Ctor = object == null ? undefined : object.constructor; 20798 if ((typeof Ctor == 'function' && Ctor.prototype === object) || 20799 (typeof object == 'function' ? support.enumPrototypes : isArrayLike(object))) { 20800 return shimKeys(object); 20801 } 20802 return isObject(object) ? nativeKeys(object) : []; 20803 }; 20804 20805 module.exports = keys; 20806 20807 },{"../internal/getNative":118,"../internal/isArrayLike":123,"../internal/shimKeys":138,"../lang/isObject":148,"../support":157}],154:[function(require,module,exports){ 20808 var arrayEach = require('../internal/arrayEach'), 20809 isArguments = require('../lang/isArguments'), 20810 isArray = require('../lang/isArray'), 20811 isFunction = require('../lang/isFunction'), 20812 isIndex = require('../internal/isIndex'), 20813 isLength = require('../internal/isLength'), 20814 isObject = require('../lang/isObject'), 20815 isString = require('../lang/isString'), 20816 support = require('../support'); 20817 20818 /** `Object#toString` result references. */ 20819 var arrayTag = '[object Array]', 20820 boolTag = '[object Boolean]', 20821 dateTag = '[object Date]', 20822 errorTag = '[object Error]', 20823 funcTag = '[object Function]', 20824 numberTag = '[object Number]', 20825 objectTag = '[object Object]', 20826 regexpTag = '[object RegExp]', 20827 stringTag = '[object String]'; 20828 20829 /** Used to fix the JScript `[[DontEnum]]` bug. */ 20830 var shadowProps = [ 20831 'constructor', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable', 20832 'toLocaleString', 'toString', 'valueOf' 20833 ]; 20834 20835 /** Used for native method references. */ 20836 var errorProto = Error.prototype, 20837 objectProto = Object.prototype, 20838 stringProto = String.prototype; 20839 20840 /** Used to check objects for own properties. */ 20841 var hasOwnProperty = objectProto.hasOwnProperty; 20842 20843 /** 20844 * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) 20845 * of values. 20846 */ 20847 var objToString = objectProto.toString; 20848 20849 /** Used to avoid iterating over non-enumerable properties in IE < 9. */ 20850 var nonEnumProps = {}; 20851 nonEnumProps[arrayTag] = nonEnumProps[dateTag] = nonEnumProps[numberTag] = { 'constructor': true, 'toLocaleString': true, 'toString': true, 'valueOf': true }; 20852 nonEnumProps[boolTag] = nonEnumProps[stringTag] = { 'constructor': true, 'toString': true, 'valueOf': true }; 20853 nonEnumProps[errorTag] = nonEnumProps[funcTag] = nonEnumProps[regexpTag] = { 'constructor': true, 'toString': true }; 20854 nonEnumProps[objectTag] = { 'constructor': true }; 20855 20856 arrayEach(shadowProps, function(key) { 20857 for (var tag in nonEnumProps) { 20858 if (hasOwnProperty.call(nonEnumProps, tag)) { 20859 var props = nonEnumProps[tag]; 20860 props[key] = hasOwnProperty.call(props, key); 20861 } 20862 } 20863 }); 20864 20865 /** 20866 * Creates an array of the own and inherited enumerable property names of `object`. 20867 * 20868 * **Note:** Non-object values are coerced to objects. 20869 * 20870 * @static 20871 * @memberOf _ 20872 * @category Object 20873 * @param {Object} object The object to query. 20874 * @returns {Array} Returns the array of property names. 20875 * @example 20876 * 20877 * function Foo() { 20878 * this.a = 1; 20879 * this.b = 2; 20880 * } 20881 * 20882 * Foo.prototype.c = 3; 20883 * 20884 * _.keysIn(new Foo); 20885 * // => ['a', 'b', 'c'] (iteration order is not guaranteed) 20886 */ 20887 function keysIn(object) { 20888 if (object == null) { 20889 return []; 20890 } 20891 if (!isObject(object)) { 20892 object = Object(object); 20893 } 20894 var length = object.length; 20895 20896 length = (length && isLength(length) && 20897 (isArray(object) || isArguments(object) || isString(object)) && length) || 0; 20898 20899 var Ctor = object.constructor, 20900 index = -1, 20901 proto = (isFunction(Ctor) && Ctor.prototype) || objectProto, 20902 isProto = proto === object, 20903 result = Array(length), 20904 skipIndexes = length > 0, 20905 skipErrorProps = support.enumErrorProps && (object === errorProto || object instanceof Error), 20906 skipProto = support.enumPrototypes && isFunction(object); 20907 20908 while (++index < length) { 20909 result[index] = (index + ''); 20910 } 20911 // lodash skips the `constructor` property when it infers it's iterating 20912 // over a `prototype` object because IE < 9 can't set the `[[Enumerable]]` 20913 // attribute of an existing property and the `constructor` property of a 20914 // prototype defaults to non-enumerable. 20915 for (var key in object) { 20916 if (!(skipProto && key == 'prototype') && 20917 !(skipErrorProps && (key == 'message' || key == 'name')) && 20918 !(skipIndexes && isIndex(key, length)) && 20919 !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { 20920 result.push(key); 20921 } 20922 } 20923 if (support.nonEnumShadows && object !== objectProto) { 20924 var tag = object === stringProto ? stringTag : (object === errorProto ? errorTag : objToString.call(object)), 20925 nonEnums = nonEnumProps[tag] || nonEnumProps[objectTag]; 20926 20927 if (tag == objectTag) { 20928 proto = objectProto; 20929 } 20930 length = shadowProps.length; 20931 while (length--) { 20932 key = shadowProps[length]; 20933 var nonEnum = nonEnums[key]; 20934 if (!(isProto && nonEnum) && 20935 (nonEnum ? hasOwnProperty.call(object, key) : object[key] !== proto[key])) { 20936 result.push(key); 20937 } 20938 } 20939 } 20940 return result; 20941 } 20942 20943 module.exports = keysIn; 20944 20945 },{"../internal/arrayEach":67,"../internal/isIndex":125,"../internal/isLength":129,"../lang/isArguments":143,"../lang/isArray":144,"../lang/isFunction":146,"../lang/isObject":148,"../lang/isString":150,"../support":157}],155:[function(require,module,exports){ 20946 var keys = require('./keys'), 20947 toObject = require('../internal/toObject'); 20948 20949 /** 20950 * Creates a two dimensional array of the key-value pairs for `object`, 20951 * e.g. `[[key1, value1], [key2, value2]]`. 20952 * 20953 * @static 20954 * @memberOf _ 20955 * @category Object 20956 * @param {Object} object The object to query. 20957 * @returns {Array} Returns the new array of key-value pairs. 20958 * @example 20959 * 20960 * _.pairs({ 'barney': 36, 'fred': 40 }); 20961 * // => [['barney', 36], ['fred', 40]] (iteration order is not guaranteed) 20962 */ 20963 function pairs(object) { 20964 object = toObject(object); 20965 20966 var index = -1, 20967 props = keys(object), 20968 length = props.length, 20969 result = Array(length); 20970 20971 while (++index < length) { 20972 var key = props[index]; 20973 result[index] = [key, object[key]]; 20974 } 20975 return result; 20976 } 20977 20978 module.exports = pairs; 20979 20980 },{"../internal/toObject":139,"./keys":153}],156:[function(require,module,exports){ 20981 var baseValues = require('../internal/baseValues'), 20982 keys = require('./keys'); 20983 20984 /** 20985 * Creates an array of the own enumerable property values of `object`. 20986 * 20987 * **Note:** Non-object values are coerced to objects. 20988 * 20989 * @static 20990 * @memberOf _ 20991 * @category Object 20992 * @param {Object} object The object to query. 20993 * @returns {Array} Returns the array of property values. 20994 * @example 20995 * 20996 * function Foo() { 20997 * this.a = 1; 20998 * this.b = 2; 20999 * } 21000 * 21001 * Foo.prototype.c = 3; 21002 * 21003 * _.values(new Foo); 21004 * // => [1, 2] (iteration order is not guaranteed) 21005 * 21006 * _.values('hi'); 21007 * // => ['h', 'i'] 21008 */ 21009 function values(object) { 21010 return baseValues(object, keys(object)); 21011 } 21012 21013 module.exports = values; 21014 21015 },{"../internal/baseValues":95,"./keys":153}],157:[function(require,module,exports){ 21016 /** Used for native method references. */ 21017 var arrayProto = Array.prototype, 21018 errorProto = Error.prototype, 21019 objectProto = Object.prototype; 21020 21021 /** Native method references. */ 21022 var propertyIsEnumerable = objectProto.propertyIsEnumerable, 21023 splice = arrayProto.splice; 21024 21025 /** 21026 * An object environment feature flags. 21027 * 21028 * @static 21029 * @memberOf _ 21030 * @type Object 21031 */ 21032 var support = {}; 21033 21034 (function(x) { 21035 var Ctor = function() { this.x = x; }, 21036 object = { '0': x, 'length': x }, 21037 props = []; 21038 21039 Ctor.prototype = { 'valueOf': x, 'y': x }; 21040 for (var key in new Ctor) { props.push(key); } 21041 21042 /** 21043 * Detect if `name` or `message` properties of `Error.prototype` are 21044 * enumerable by default (IE < 9, Safari < 5.1). 21045 * 21046 * @memberOf _.support 21047 * @type boolean 21048 */ 21049 support.enumErrorProps = propertyIsEnumerable.call(errorProto, 'message') || 21050 propertyIsEnumerable.call(errorProto, 'name'); 21051 21052 /** 21053 * Detect if `prototype` properties are enumerable by default. 21054 * 21055 * Firefox < 3.6, Opera > 9.50 - Opera < 11.60, and Safari < 5.1 21056 * (if the prototype or a property on the prototype has been set) 21057 * incorrectly set the `[[Enumerable]]` value of a function's `prototype` 21058 * property to `true`. 21059 * 21060 * @memberOf _.support 21061 * @type boolean 21062 */ 21063 support.enumPrototypes = propertyIsEnumerable.call(Ctor, 'prototype'); 21064 21065 /** 21066 * Detect if properties shadowing those on `Object.prototype` are non-enumerable. 21067 * 21068 * In IE < 9 an object's own properties, shadowing non-enumerable ones, 21069 * are made non-enumerable as well (a.k.a the JScript `[[DontEnum]]` bug). 21070 * 21071 * @memberOf _.support 21072 * @type boolean 21073 */ 21074 support.nonEnumShadows = !/valueOf/.test(props); 21075 21076 /** 21077 * Detect if own properties are iterated after inherited properties (IE < 9). 21078 * 21079 * @memberOf _.support 21080 * @type boolean 21081 */ 21082 support.ownLast = props[0] != 'x'; 21083 21084 /** 21085 * Detect if `Array#shift` and `Array#splice` augment array-like objects 21086 * correctly. 21087 * 21088 * Firefox < 10, compatibility modes of IE 8, and IE < 9 have buggy Array 21089 * `shift()` and `splice()` functions that fail to remove the last element, 21090 * `value[0]`, of array-like objects even though the "length" property is 21091 * set to `0`. The `shift()` method is buggy in compatibility modes of IE 8, 21092 * while `splice()` is buggy regardless of mode in IE < 9. 21093 * 21094 * @memberOf _.support 21095 * @type boolean 21096 */ 21097 support.spliceObjects = (splice.call(object, 0, 1), !object[0]); 21098 21099 /** 21100 * Detect lack of support for accessing string characters by index. 21101 * 21102 * IE < 8 can't access characters by index. IE 8 can only access characters 21103 * by index on string literals, not string objects. 21104 * 21105 * @memberOf _.support 21106 * @type boolean 21107 */ 21108 support.unindexedChars = ('x'[0] + Object('x')[0]) != 'xx'; 21109 }(1, 0)); 21110 21111 module.exports = support; 21112 21113 },{}],158:[function(require,module,exports){ 21114 /** 21115 * This method returns the first argument provided to it. 21116 * 21117 * @static 21118 * @memberOf _ 21119 * @category Utility 21120 * @param {*} value Any value. 21121 * @returns {*} Returns `value`. 21122 * @example 21123 * 21124 * var object = { 'user': 'fred' }; 21125 * 21126 * _.identity(object) === object; 21127 * // => true 21128 */ 21129 function identity(value) { 21130 return value; 21131 } 21132 21133 module.exports = identity; 21134 21135 },{}],159:[function(require,module,exports){ 21136 /** 21137 * A no-operation function that returns `undefined` regardless of the 21138 * arguments it receives. 21139 * 21140 * @static 21141 * @memberOf _ 21142 * @category Utility 21143 * @example 21144 * 21145 * var object = { 'user': 'fred' }; 21146 * 21147 * _.noop(object) === undefined; 21148 * // => true 21149 */ 21150 function noop() { 21151 // No operation performed. 21152 } 21153 21154 module.exports = noop; 21155 21156 },{}],160:[function(require,module,exports){ 21157 var baseProperty = require('../internal/baseProperty'), 21158 basePropertyDeep = require('../internal/basePropertyDeep'), 21159 isKey = require('../internal/isKey'); 21160 21161 /** 21162 * Creates a function that returns the property value at `path` on a 21163 * given object. 21164 * 21165 * @static 21166 * @memberOf _ 21167 * @category Utility 21168 * @param {Array|string} path The path of the property to get. 21169 * @returns {Function} Returns the new function. 21170 * @example 21171 * 21172 * var objects = [ 21173 * { 'a': { 'b': { 'c': 2 } } }, 21174 * { 'a': { 'b': { 'c': 1 } } } 21175 * ]; 21176 * 21177 * _.map(objects, _.property('a.b.c')); 21178 * // => [2, 1] 21179 * 21180 * _.pluck(_.sortBy(objects, _.property(['a', 'b', 'c'])), 'a.b.c'); 21181 * // => [1, 2] 21182 */ 21183 function property(path) { 21184 return isKey(path) ? baseProperty(path) : basePropertyDeep(path); 21185 } 21186 21187 module.exports = property; 21188 21189 },{"../internal/baseProperty":90,"../internal/basePropertyDeep":91,"../internal/isKey":127}],161:[function(require,module,exports){ 21190 (function (process){ 21191 // vim:ts=4:sts=4:sw=4: 21192 /*! 21193 * 21194 * Copyright 2009-2012 Kris Kowal under the terms of the MIT 21195 * license found at http://github.com/kriskowal/q/raw/master/LICENSE 21196 * 21197 * With parts by Tyler Close 21198 * Copyright 2007-2009 Tyler Close under the terms of the MIT X license found 21199 * at http://www.opensource.org/licenses/mit-license.html 21200 * Forked at ref_send.js version: 2009-05-11 21201 * 21202 * With parts by Mark Miller 21203 * Copyright (C) 2011 Google Inc. 21204 * 21205 * Licensed under the Apache License, Version 2.0 (the "License"); 21206 * you may not use this file except in compliance with the License. 21207 * You may obtain a copy of the License at 21208 * 21209 * http://www.apache.org/licenses/LICENSE-2.0 21210 * 21211 * Unless required by applicable law or agreed to in writing, software 21212 * distributed under the License is distributed on an "AS IS" BASIS, 21213 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 21214 * See the License for the specific language governing permissions and 21215 * limitations under the License. 21216 * 21217 */ 21218 21219 (function (definition) { 21220 "use strict"; 21221 21222 // This file will function properly as a <script> tag, or a module 21223 // using CommonJS and NodeJS or RequireJS module formats. In 21224 // Common/Node/RequireJS, the module exports the Q API and when 21225 // executed as a simple <script>, it creates a Q global instead. 21226 21227 // Montage Require 21228 if (typeof bootstrap === "function") { 21229 bootstrap("promise", definition); 21230 21231 // CommonJS 21232 } else if (typeof exports === "object" && typeof module === "object") { 21233 module.exports = definition(); 21234 21235 // RequireJS 21236 } else if (typeof define === "function" && define.amd) { 21237 define(definition); 21238 21239 // SES (Secure EcmaScript) 21240 } else if (typeof ses !== "undefined") { 21241 if (!ses.ok()) { 21242 return; 21243 } else { 21244 ses.makeQ = definition; 21245 } 21246 21247 // <script> 21248 } else if (typeof window !== "undefined" || typeof self !== "undefined") { 21249 // Prefer window over self for add-on scripts. Use self for 21250 // non-windowed contexts. 21251 var global = typeof window !== "undefined" ? window : self; 21252 21253 // Get the `window` object, save the previous Q global 21254 // and initialize Q as a global. 21255 var previousQ = global.Q; 21256 global.Q = definition(); 21257 21258 // Add a noConflict function so Q can be removed from the 21259 // global namespace. 21260 global.Q.noConflict = function () { 21261 global.Q = previousQ; 21262 return this; 21263 }; 21264 21265 } else { 21266 throw new Error("This environment was not anticipated by Q. Please file a bug."); 21267 } 21268 21269 })(function () { 21270 "use strict"; 21271 21272 var hasStacks = false; 21273 try { 21274 throw new Error(); 21275 } catch (e) { 21276 hasStacks = !!e.stack; 21277 } 21278 21279 // All code after this point will be filtered from stack traces reported 21280 // by Q. 21281 var qStartingLine = captureLine(); 21282 var qFileName; 21283 21284 // shims 21285 21286 // used for fallback in "allResolved" 21287 var noop = function () {}; 21288 21289 // Use the fastest possible means to execute a task in a future turn 21290 // of the event loop. 21291 var nextTick =(function () { 21292 // linked list of tasks (single, with head node) 21293 var head = {task: void 0, next: null}; 21294 var tail = head; 21295 var flushing = false; 21296 var requestTick = void 0; 21297 var isNodeJS = false; 21298 // queue for late tasks, used by unhandled rejection tracking 21299 var laterQueue = []; 21300 21301 function flush() { 21302 /* jshint loopfunc: true */ 21303 var task, domain; 21304 21305 while (head.next) { 21306 head = head.next; 21307 task = head.task; 21308 head.task = void 0; 21309 domain = head.domain; 21310 21311 if (domain) { 21312 head.domain = void 0; 21313 domain.enter(); 21314 } 21315 runSingle(task, domain); 21316 21317 } 21318 while (laterQueue.length) { 21319 task = laterQueue.pop(); 21320 runSingle(task); 21321 } 21322 flushing = false; 21323 } 21324 // runs a single function in the async queue 21325 function runSingle(task, domain) { 21326 try { 21327 task(); 21328 21329 } catch (e) { 21330 if (isNodeJS) { 21331 // In node, uncaught exceptions are considered fatal errors. 21332 // Re-throw them synchronously to interrupt flushing! 21333 21334 // Ensure continuation if the uncaught exception is suppressed 21335 // listening "uncaughtException" events (as domains does). 21336 // Continue in next event to avoid tick recursion. 21337 if (domain) { 21338 domain.exit(); 21339 } 21340 setTimeout(flush, 0); 21341 if (domain) { 21342 domain.enter(); 21343 } 21344 21345 throw e; 21346 21347 } else { 21348 // In browsers, uncaught exceptions are not fatal. 21349 // Re-throw them asynchronously to avoid slow-downs. 21350 setTimeout(function () { 21351 throw e; 21352 }, 0); 21353 } 21354 } 21355 21356 if (domain) { 21357 domain.exit(); 21358 } 21359 } 21360 21361 nextTick = function (task) { 21362 tail = tail.next = { 21363 task: task, 21364 domain: isNodeJS && process.domain, 21365 next: null 21366 }; 21367 21368 if (!flushing) { 21369 flushing = true; 21370 requestTick(); 21371 } 21372 }; 21373 21374 if (typeof process === "object" && 21375 process.toString() === "[object process]" && process.nextTick) { 21376 // Ensure Q is in a real Node environment, with a `process.nextTick`. 21377 // To see through fake Node environments: 21378 // * Mocha test runner - exposes a `process` global without a `nextTick` 21379 // * Browserify - exposes a `process.nexTick` function that uses 21380 // `setTimeout`. In this case `setImmediate` is preferred because 21381 // it is faster. Browserify's `process.toString()` yields 21382 // "[object Object]", while in a real Node environment 21383 // `process.nextTick()` yields "[object process]". 21384 isNodeJS = true; 21385 21386 requestTick = function () { 21387 process.nextTick(flush); 21388 }; 21389 21390 } else if (typeof setImmediate === "function") { 21391 // In IE10, Node.js 0.9+, or https://github.com/NobleJS/setImmediate 21392 if (typeof window !== "undefined") { 21393 requestTick = setImmediate.bind(window, flush); 21394 } else { 21395 requestTick = function () { 21396 setImmediate(flush); 21397 }; 21398 } 21399 21400 } else if (typeof MessageChannel !== "undefined") { 21401 // modern browsers 21402 // http://www.nonblocking.io/2011/06/windownexttick.html 21403 var channel = new MessageChannel(); 21404 // At least Safari Version 6.0.5 (8536.30.1) intermittently cannot create 21405 // working message ports the first time a page loads. 21406 channel.port1.onmessage = function () { 21407 requestTick = requestPortTick; 21408 channel.port1.onmessage = flush; 21409 flush(); 21410 }; 21411 var requestPortTick = function () { 21412 // Opera requires us to provide a message payload, regardless of 21413 // whether we use it. 21414 channel.port2.postMessage(0); 21415 }; 21416 requestTick = function () { 21417 setTimeout(flush, 0); 21418 requestPortTick(); 21419 }; 21420 21421 } else { 21422 // old browsers 21423 requestTick = function () { 21424 setTimeout(flush, 0); 21425 }; 21426 } 21427 // runs a task after all other tasks have been run 21428 // this is useful for unhandled rejection tracking that needs to happen 21429 // after all `then`d tasks have been run. 21430 nextTick.runAfter = function (task) { 21431 laterQueue.push(task); 21432 if (!flushing) { 21433 flushing = true; 21434 requestTick(); 21435 } 21436 }; 21437 return nextTick; 21438 })(); 21439 21440 // Attempt to make generics safe in the face of downstream 21441 // modifications. 21442 // There is no situation where this is necessary. 21443 // If you need a security guarantee, these primordials need to be 21444 // deeply frozen anyway, and if you don’t need a security guarantee, 21445 // this is just plain paranoid. 21446 // However, this **might** have the nice side-effect of reducing the size of 21447 // the minified code by reducing x.call() to merely x() 21448 // See Mark Miller’s explanation of what this does. 21449 // http://wiki.ecmascript.org/doku.php?id=conventions:safe_meta_programming 21450 var call = Function.call; 21451 function uncurryThis(f) { 21452 return function () { 21453 return call.apply(f, arguments); 21454 }; 21455 } 21456 // This is equivalent, but slower: 21457 // uncurryThis = Function_bind.bind(Function_bind.call); 21458 // http://jsperf.com/uncurrythis 21459 21460 var array_slice = uncurryThis(Array.prototype.slice); 21461 21462 var array_reduce = uncurryThis( 21463 Array.prototype.reduce || function (callback, basis) { 21464 var index = 0, 21465 length = this.length; 21466 // concerning the initial value, if one is not provided 21467 if (arguments.length === 1) { 21468 // seek to the first value in the array, accounting 21469 // for the possibility that is is a sparse array 21470 do { 21471 if (index in this) { 21472 basis = this[index++]; 21473 break; 21474 } 21475 if (++index >= length) { 21476 throw new TypeError(); 21477 } 21478 } while (1); 21479 } 21480 // reduce 21481 for (; index < length; index++) { 21482 // account for the possibility that the array is sparse 21483 if (index in this) { 21484 basis = callback(basis, this[index], index); 21485 } 21486 } 21487 return basis; 21488 } 21489 ); 21490 21491 var array_indexOf = uncurryThis( 21492 Array.prototype.indexOf || function (value) { 21493 // not a very good shim, but good enough for our one use of it 21494 for (var i = 0; i < this.length; i++) { 21495 if (this[i] === value) { 21496 return i; 21497 } 21498 } 21499 return -1; 21500 } 21501 ); 21502 21503 var array_map = uncurryThis( 21504 Array.prototype.map || function (callback, thisp) { 21505 var self = this; 21506 var collect = []; 21507 array_reduce(self, function (undefined, value, index) { 21508 collect.push(callback.call(thisp, value, index, self)); 21509 }, void 0); 21510 return collect; 21511 } 21512 ); 21513 21514 var object_create = Object.create || function (prototype) { 21515 function Type() { } 21516 Type.prototype = prototype; 21517 return new Type(); 21518 }; 21519 21520 var object_hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty); 21521 21522 var object_keys = Object.keys || function (object) { 21523 var keys = []; 21524 for (var key in object) { 21525 if (object_hasOwnProperty(object, key)) { 21526 keys.push(key); 21527 } 21528 } 21529 return keys; 21530 }; 21531 21532 var object_toString = uncurryThis(Object.prototype.toString); 21533 21534 function isObject(value) { 21535 return value === Object(value); 21536 } 21537 21538 // generator related shims 21539 21540 // FIXME: Remove this function once ES6 generators are in SpiderMonkey. 21541 function isStopIteration(exception) { 21542 return ( 21543 object_toString(exception) === "[object StopIteration]" || 21544 exception instanceof QReturnValue 21545 ); 21546 } 21547 21548 // FIXME: Remove this helper and Q.return once ES6 generators are in 21549 // SpiderMonkey. 21550 var QReturnValue; 21551 if (typeof ReturnValue !== "undefined") { 21552 QReturnValue = ReturnValue; 21553 } else { 21554 QReturnValue = function (value) { 21555 this.value = value; 21556 }; 21557 } 21558 21559 // long stack traces 21560 21561 var STACK_JUMP_SEPARATOR = "From previous event:"; 21562 21563 function makeStackTraceLong(error, promise) { 21564 // If possible, transform the error stack trace by removing Node and Q 21565 // cruft, then concatenating with the stack trace of `promise`. See #57. 21566 if (hasStacks && 21567 promise.stack && 21568 typeof error === "object" && 21569 error !== null && 21570 error.stack && 21571 error.stack.indexOf(STACK_JUMP_SEPARATOR) === -1 21572 ) { 21573 var stacks = []; 21574 for (var p = promise; !!p; p = p.source) { 21575 if (p.stack) { 21576 stacks.unshift(p.stack); 21577 } 21578 } 21579 stacks.unshift(error.stack); 21580 21581 var concatedStacks = stacks.join("\n" + STACK_JUMP_SEPARATOR + "\n"); 21582 error.stack = filterStackString(concatedStacks); 21583 } 21584 } 21585 21586 function filterStackString(stackString) { 21587 var lines = stackString.split("\n"); 21588 var desiredLines = []; 21589 for (var i = 0; i < lines.length; ++i) { 21590 var line = lines[i]; 21591 21592 if (!isInternalFrame(line) && !isNodeFrame(line) && line) { 21593 desiredLines.push(line); 21594 } 21595 } 21596 return desiredLines.join("\n"); 21597 } 21598 21599 function isNodeFrame(stackLine) { 21600 return stackLine.indexOf("(module.js:") !== -1 || 21601 stackLine.indexOf("(node.js:") !== -1; 21602 } 21603 21604 function getFileNameAndLineNumber(stackLine) { 21605 // Named functions: "at functionName (filename:lineNumber:columnNumber)" 21606 // In IE10 function name can have spaces ("Anonymous function") O_o 21607 var attempt1 = /at .+ \((.+):(\d+):(?:\d+)\)$/.exec(stackLine); 21608 if (attempt1) { 21609 return [attempt1[1], Number(attempt1[2])]; 21610 } 21611 21612 // Anonymous functions: "at filename:lineNumber:columnNumber" 21613 var attempt2 = /at ([^ ]+):(\d+):(?:\d+)$/.exec(stackLine); 21614 if (attempt2) { 21615 return [attempt2[1], Number(attempt2[2])]; 21616 } 21617 21618 // Firefox style: "function@filename:lineNumber or @filename:lineNumber" 21619 var attempt3 = /.*@(.+):(\d+)$/.exec(stackLine); 21620 if (attempt3) { 21621 return [attempt3[1], Number(attempt3[2])]; 21622 } 21623 } 21624 21625 function isInternalFrame(stackLine) { 21626 var fileNameAndLineNumber = getFileNameAndLineNumber(stackLine); 21627 21628 if (!fileNameAndLineNumber) { 21629 return false; 21630 } 21631 21632 var fileName = fileNameAndLineNumber[0]; 21633 var lineNumber = fileNameAndLineNumber[1]; 21634 21635 return fileName === qFileName && 21636 lineNumber >= qStartingLine && 21637 lineNumber <= qEndingLine; 21638 } 21639 21640 // discover own file name and line number range for filtering stack 21641 // traces 21642 function captureLine() { 21643 if (!hasStacks) { 21644 return; 21645 } 21646 21647 try { 21648 throw new Error(); 21649 } catch (e) { 21650 var lines = e.stack.split("\n"); 21651 var firstLine = lines[0].indexOf("@") > 0 ? lines[1] : lines[2]; 21652 var fileNameAndLineNumber = getFileNameAndLineNumber(firstLine); 21653 if (!fileNameAndLineNumber) { 21654 return; 21655 } 21656 21657 qFileName = fileNameAndLineNumber[0]; 21658 return fileNameAndLineNumber[1]; 21659 } 21660 } 21661 21662 function deprecate(callback, name, alternative) { 21663 return function () { 21664 if (typeof console !== "undefined" && 21665 typeof console.warn === "function") { 21666 console.warn(name + " is deprecated, use " + alternative + 21667 " instead.", new Error("").stack); 21668 } 21669 return callback.apply(callback, arguments); 21670 }; 21671 } 21672 21673 // end of shims 21674 // beginning of real work 21675 21676 /** 21677 * Constructs a promise for an immediate reference, passes promises through, or 21678 * coerces promises from different systems. 21679 * @param value immediate reference or promise 21680 */ 21681 function Q(value) { 21682 // If the object is already a Promise, return it directly. This enables 21683 // the resolve function to both be used to created references from objects, 21684 // but to tolerably coerce non-promises to promises. 21685 if (value instanceof Promise) { 21686 return value; 21687 } 21688 21689 // assimilate thenables 21690 if (isPromiseAlike(value)) { 21691 return coerce(value); 21692 } else { 21693 return fulfill(value); 21694 } 21695 } 21696 Q.resolve = Q; 21697 21698 /** 21699 * Performs a task in a future turn of the event loop. 21700 * @param {Function} task 21701 */ 21702 Q.nextTick = nextTick; 21703 21704 /** 21705 * Controls whether or not long stack traces will be on 21706 */ 21707 Q.longStackSupport = false; 21708 21709 // enable long stacks if Q_DEBUG is set 21710 if (typeof process === "object" && process && process.env && process.env.Q_DEBUG) { 21711 Q.longStackSupport = true; 21712 } 21713 21714 /** 21715 * Constructs a {promise, resolve, reject} object. 21716 * 21717 * `resolve` is a callback to invoke with a more resolved value for the 21718 * promise. To fulfill the promise, invoke `resolve` with any value that is 21719 * not a thenable. To reject the promise, invoke `resolve` with a rejected 21720 * thenable, or invoke `reject` with the reason directly. To resolve the 21721 * promise to another thenable, thus putting it in the same state, invoke 21722 * `resolve` with that other thenable. 21723 */ 21724 Q.defer = defer; 21725 function defer() { 21726 // if "messages" is an "Array", that indicates that the promise has not yet 21727 // been resolved. If it is "undefined", it has been resolved. Each 21728 // element of the messages array is itself an array of complete arguments to 21729 // forward to the resolved promise. We coerce the resolution value to a 21730 // promise using the `resolve` function because it handles both fully 21731 // non-thenable values and other thenables gracefully. 21732 var messages = [], progressListeners = [], resolvedPromise; 21733 21734 var deferred = object_create(defer.prototype); 21735 var promise = object_create(Promise.prototype); 21736 21737 promise.promiseDispatch = function (resolve, op, operands) { 21738 var args = array_slice(arguments); 21739 if (messages) { 21740 messages.push(args); 21741 if (op === "when" && operands[1]) { // progress operand 21742 progressListeners.push(operands[1]); 21743 } 21744 } else { 21745 Q.nextTick(function () { 21746 resolvedPromise.promiseDispatch.apply(resolvedPromise, args); 21747 }); 21748 } 21749 }; 21750 21751 // XXX deprecated 21752 promise.valueOf = function () { 21753 if (messages) { 21754 return promise; 21755 } 21756 var nearerValue = nearer(resolvedPromise); 21757 if (isPromise(nearerValue)) { 21758 resolvedPromise = nearerValue; // shorten chain 21759 } 21760 return nearerValue; 21761 }; 21762 21763 promise.inspect = function () { 21764 if (!resolvedPromise) { 21765 return { state: "pending" }; 21766 } 21767 return resolvedPromise.inspect(); 21768 }; 21769 21770 if (Q.longStackSupport && hasStacks) { 21771 try { 21772 throw new Error(); 21773 } catch (e) { 21774 // NOTE: don't try to use `Error.captureStackTrace` or transfer the 21775 // accessor around; that causes memory leaks as per GH-111. Just 21776 // reify the stack trace as a string ASAP. 21777 // 21778 // At the same time, cut off the first line; it's always just 21779 // "[object Promise]\n", as per the `toString`. 21780 promise.stack = e.stack.substring(e.stack.indexOf("\n") + 1); 21781 } 21782 } 21783 21784 // NOTE: we do the checks for `resolvedPromise` in each method, instead of 21785 // consolidating them into `become`, since otherwise we'd create new 21786 // promises with the lines `become(whatever(value))`. See e.g. GH-252. 21787 21788 function become(newPromise) { 21789 resolvedPromise = newPromise; 21790 promise.source = newPromise; 21791 21792 array_reduce(messages, function (undefined, message) { 21793 Q.nextTick(function () { 21794 newPromise.promiseDispatch.apply(newPromise, message); 21795 }); 21796 }, void 0); 21797 21798 messages = void 0; 21799 progressListeners = void 0; 21800 } 21801 21802 deferred.promise = promise; 21803 deferred.resolve = function (value) { 21804 if (resolvedPromise) { 21805 return; 21806 } 21807 21808 become(Q(value)); 21809 }; 21810 21811 deferred.fulfill = function (value) { 21812 if (resolvedPromise) { 21813 return; 21814 } 21815 21816 become(fulfill(value)); 21817 }; 21818 deferred.reject = function (reason) { 21819 if (resolvedPromise) { 21820 return; 21821 } 21822 21823 become(reject(reason)); 21824 }; 21825 deferred.notify = function (progress) { 21826 if (resolvedPromise) { 21827 return; 21828 } 21829 21830 array_reduce(progressListeners, function (undefined, progressListener) { 21831 Q.nextTick(function () { 21832 progressListener(progress); 21833 }); 21834 }, void 0); 21835 }; 21836 21837 return deferred; 21838 } 21839 21840 /** 21841 * Creates a Node-style callback that will resolve or reject the deferred 21842 * promise. 21843 * @returns a nodeback 21844 */ 21845 defer.prototype.makeNodeResolver = function () { 21846 var self = this; 21847 return function (error, value) { 21848 if (error) { 21849 self.reject(error); 21850 } else if (arguments.length > 2) { 21851 self.resolve(array_slice(arguments, 1)); 21852 } else { 21853 self.resolve(value); 21854 } 21855 }; 21856 }; 21857 21858 /** 21859 * @param resolver {Function} a function that returns nothing and accepts 21860 * the resolve, reject, and notify functions for a deferred. 21861 * @returns a promise that may be resolved with the given resolve and reject 21862 * functions, or rejected by a thrown exception in resolver 21863 */ 21864 Q.Promise = promise; // ES6 21865 Q.promise = promise; 21866 function promise(resolver) { 21867 if (typeof resolver !== "function") { 21868 throw new TypeError("resolver must be a function."); 21869 } 21870 var deferred = defer(); 21871 try { 21872 resolver(deferred.resolve, deferred.reject, deferred.notify); 21873 } catch (reason) { 21874 deferred.reject(reason); 21875 } 21876 return deferred.promise; 21877 } 21878 21879 promise.race = race; // ES6 21880 promise.all = all; // ES6 21881 promise.reject = reject; // ES6 21882 promise.resolve = Q; // ES6 21883 21884 // XXX experimental. This method is a way to denote that a local value is 21885 // serializable and should be immediately dispatched to a remote upon request, 21886 // instead of passing a reference. 21887 Q.passByCopy = function (object) { 21888 //freeze(object); 21889 //passByCopies.set(object, true); 21890 return object; 21891 }; 21892 21893 Promise.prototype.passByCopy = function () { 21894 //freeze(object); 21895 //passByCopies.set(object, true); 21896 return this; 21897 }; 21898 21899 /** 21900 * If two promises eventually fulfill to the same value, promises that value, 21901 * but otherwise rejects. 21902 * @param x {Any*} 21903 * @param y {Any*} 21904 * @returns {Any*} a promise for x and y if they are the same, but a rejection 21905 * otherwise. 21906 * 21907 */ 21908 Q.join = function (x, y) { 21909 return Q(x).join(y); 21910 }; 21911 21912 Promise.prototype.join = function (that) { 21913 return Q([this, that]).spread(function (x, y) { 21914 if (x === y) { 21915 // TODO: "===" should be Object.is or equiv 21916 return x; 21917 } else { 21918 throw new Error("Can't join: not the same: " + x + " " + y); 21919 } 21920 }); 21921 }; 21922 21923 /** 21924 * Returns a promise for the first of an array of promises to become settled. 21925 * @param answers {Array[Any*]} promises to race 21926 * @returns {Any*} the first promise to be settled 21927 */ 21928 Q.race = race; 21929 function race(answerPs) { 21930 return promise(function (resolve, reject) { 21931 // Switch to this once we can assume at least ES5 21932 // answerPs.forEach(function (answerP) { 21933 // Q(answerP).then(resolve, reject); 21934 // }); 21935 // Use this in the meantime 21936 for (var i = 0, len = answerPs.length; i < len; i++) { 21937 Q(answerPs[i]).then(resolve, reject); 21938 } 21939 }); 21940 } 21941 21942 Promise.prototype.race = function () { 21943 return this.then(Q.race); 21944 }; 21945 21946 /** 21947 * Constructs a Promise with a promise descriptor object and optional fallback 21948 * function. The descriptor contains methods like when(rejected), get(name), 21949 * set(name, value), post(name, args), and delete(name), which all 21950 * return either a value, a promise for a value, or a rejection. The fallback 21951 * accepts the operation name, a resolver, and any further arguments that would 21952 * have been forwarded to the appropriate method above had a method been 21953 * provided with the proper name. The API makes no guarantees about the nature 21954 * of the returned object, apart from that it is usable whereever promises are 21955 * bought and sold. 21956 */ 21957 Q.makePromise = Promise; 21958 function Promise(descriptor, fallback, inspect) { 21959 if (fallback === void 0) { 21960 fallback = function (op) { 21961 return reject(new Error( 21962 "Promise does not support operation: " + op 21963 )); 21964 }; 21965 } 21966 if (inspect === void 0) { 21967 inspect = function () { 21968 return {state: "unknown"}; 21969 }; 21970 } 21971 21972 var promise = object_create(Promise.prototype); 21973 21974 promise.promiseDispatch = function (resolve, op, args) { 21975 var result; 21976 try { 21977 if (descriptor[op]) { 21978 result = descriptor[op].apply(promise, args); 21979 } else { 21980 result = fallback.call(promise, op, args); 21981 } 21982 } catch (exception) { 21983 result = reject(exception); 21984 } 21985 if (resolve) { 21986 resolve(result); 21987 } 21988 }; 21989 21990 promise.inspect = inspect; 21991 21992 // XXX deprecated `valueOf` and `exception` support 21993 if (inspect) { 21994 var inspected = inspect(); 21995 if (inspected.state === "rejected") { 21996 promise.exception = inspected.reason; 21997 } 21998 21999 promise.valueOf = function () { 22000 var inspected = inspect(); 22001 if (inspected.state === "pending" || 22002 inspected.state === "rejected") { 22003 return promise; 22004 } 22005 return inspected.value; 22006 }; 22007 } 22008 22009 return promise; 22010 } 22011 22012 Promise.prototype.toString = function () { 22013 return "[object Promise]"; 22014 }; 22015 22016 Promise.prototype.then = function (fulfilled, rejected, progressed) { 22017 var self = this; 22018 var deferred = defer(); 22019 var done = false; // ensure the untrusted promise makes at most a 22020 // single call to one of the callbacks 22021 22022 function _fulfilled(value) { 22023 try { 22024 return typeof fulfilled === "function" ? fulfilled(value) : value; 22025 } catch (exception) { 22026 return reject(exception); 22027 } 22028 } 22029 22030 function _rejected(exception) { 22031 if (typeof rejected === "function") { 22032 makeStackTraceLong(exception, self); 22033 try { 22034 return rejected(exception); 22035 } catch (newException) { 22036 return reject(newException); 22037 } 22038 } 22039 return reject(exception); 22040 } 22041 22042 function _progressed(value) { 22043 return typeof progressed === "function" ? progressed(value) : value; 22044 } 22045 22046 Q.nextTick(function () { 22047 self.promiseDispatch(function (value) { 22048 if (done) { 22049 return; 22050 } 22051 done = true; 22052 22053 deferred.resolve(_fulfilled(value)); 22054 }, "when", [function (exception) { 22055 if (done) { 22056 return; 22057 } 22058 done = true; 22059 22060 deferred.resolve(_rejected(exception)); 22061 }]); 22062 }); 22063 22064 // Progress propagator need to be attached in the current tick. 22065 self.promiseDispatch(void 0, "when", [void 0, function (value) { 22066 var newValue; 22067 var threw = false; 22068 try { 22069 newValue = _progressed(value); 22070 } catch (e) { 22071 threw = true; 22072 if (Q.onerror) { 22073 Q.onerror(e); 22074 } else { 22075 throw e; 22076 } 22077 } 22078 22079 if (!threw) { 22080 deferred.notify(newValue); 22081 } 22082 }]); 22083 22084 return deferred.promise; 22085 }; 22086 22087 Q.tap = function (promise, callback) { 22088 return Q(promise).tap(callback); 22089 }; 22090 22091 /** 22092 * Works almost like "finally", but not called for rejections. 22093 * Original resolution value is passed through callback unaffected. 22094 * Callback may return a promise that will be awaited for. 22095 * @param {Function} callback 22096 * @returns {Q.Promise} 22097 * @example 22098 * doSomething() 22099 * .then(...) 22100 * .tap(console.log) 22101 * .then(...); 22102 */ 22103 Promise.prototype.tap = function (callback) { 22104 callback = Q(callback); 22105 22106 return this.then(function (value) { 22107 return callback.fcall(value).thenResolve(value); 22108 }); 22109 }; 22110 22111 /** 22112 * Registers an observer on a promise. 22113 * 22114 * Guarantees: 22115 * 22116 * 1. that fulfilled and rejected will be called only once. 22117 * 2. that either the fulfilled callback or the rejected callback will be 22118 * called, but not both. 22119 * 3. that fulfilled and rejected will not be called in this turn. 22120 * 22121 * @param value promise or immediate reference to observe 22122 * @param fulfilled function to be called with the fulfilled value 22123 * @param rejected function to be called with the rejection exception 22124 * @param progressed function to be called on any progress notifications 22125 * @return promise for the return value from the invoked callback 22126 */ 22127 Q.when = when; 22128 function when(value, fulfilled, rejected, progressed) { 22129 return Q(value).then(fulfilled, rejected, progressed); 22130 } 22131 22132 Promise.prototype.thenResolve = function (value) { 22133 return this.then(function () { return value; }); 22134 }; 22135 22136 Q.thenResolve = function (promise, value) { 22137 return Q(promise).thenResolve(value); 22138 }; 22139 22140 Promise.prototype.thenReject = function (reason) { 22141 return this.then(function () { throw reason; }); 22142 }; 22143 22144 Q.thenReject = function (promise, reason) { 22145 return Q(promise).thenReject(reason); 22146 }; 22147 22148 /** 22149 * If an object is not a promise, it is as "near" as possible. 22150 * If a promise is rejected, it is as "near" as possible too. 22151 * If it’s a fulfilled promise, the fulfillment value is nearer. 22152 * If it’s a deferred promise and the deferred has been resolved, the 22153 * resolution is "nearer". 22154 * @param object 22155 * @returns most resolved (nearest) form of the object 22156 */ 22157 22158 // XXX should we re-do this? 22159 Q.nearer = nearer; 22160 function nearer(value) { 22161 if (isPromise(value)) { 22162 var inspected = value.inspect(); 22163 if (inspected.state === "fulfilled") { 22164 return inspected.value; 22165 } 22166 } 22167 return value; 22168 } 22169 22170 /** 22171 * @returns whether the given object is a promise. 22172 * Otherwise it is a fulfilled value. 22173 */ 22174 Q.isPromise = isPromise; 22175 function isPromise(object) { 22176 return object instanceof Promise; 22177 } 22178 22179 Q.isPromiseAlike = isPromiseAlike; 22180 function isPromiseAlike(object) { 22181 return isObject(object) && typeof object.then === "function"; 22182 } 22183 22184 /** 22185 * @returns whether the given object is a pending promise, meaning not 22186 * fulfilled or rejected. 22187 */ 22188 Q.isPending = isPending; 22189 function isPending(object) { 22190 return isPromise(object) && object.inspect().state === "pending"; 22191 } 22192 22193 Promise.prototype.isPending = function () { 22194 return this.inspect().state === "pending"; 22195 }; 22196 22197 /** 22198 * @returns whether the given object is a value or fulfilled 22199 * promise. 22200 */ 22201 Q.isFulfilled = isFulfilled; 22202 function isFulfilled(object) { 22203 return !isPromise(object) || object.inspect().state === "fulfilled"; 22204 } 22205 22206 Promise.prototype.isFulfilled = function () { 22207 return this.inspect().state === "fulfilled"; 22208 }; 22209 22210 /** 22211 * @returns whether the given object is a rejected promise. 22212 */ 22213 Q.isRejected = isRejected; 22214 function isRejected(object) { 22215 return isPromise(object) && object.inspect().state === "rejected"; 22216 } 22217 22218 Promise.prototype.isRejected = function () { 22219 return this.inspect().state === "rejected"; 22220 }; 22221 22222 //// BEGIN UNHANDLED REJECTION TRACKING 22223 22224 // This promise library consumes exceptions thrown in handlers so they can be 22225 // handled by a subsequent promise. The exceptions get added to this array when 22226 // they are created, and removed when they are handled. Note that in ES6 or 22227 // shimmed environments, this would naturally be a `Set`. 22228 var unhandledReasons = []; 22229 var unhandledRejections = []; 22230 var reportedUnhandledRejections = []; 22231 var trackUnhandledRejections = true; 22232 22233 function resetUnhandledRejections() { 22234 unhandledReasons.length = 0; 22235 unhandledRejections.length = 0; 22236 22237 if (!trackUnhandledRejections) { 22238 trackUnhandledRejections = true; 22239 } 22240 } 22241 22242 function trackRejection(promise, reason) { 22243 if (!trackUnhandledRejections) { 22244 return; 22245 } 22246 if (typeof process === "object" && typeof process.emit === "function") { 22247 Q.nextTick.runAfter(function () { 22248 if (array_indexOf(unhandledRejections, promise) !== -1) { 22249 process.emit("unhandledRejection", reason, promise); 22250 reportedUnhandledRejections.push(promise); 22251 } 22252 }); 22253 } 22254 22255 unhandledRejections.push(promise); 22256 if (reason && typeof reason.stack !== "undefined") { 22257 unhandledReasons.push(reason.stack); 22258 } else { 22259 unhandledReasons.push("(no stack) " + reason); 22260 } 22261 } 22262 22263 function untrackRejection(promise) { 22264 if (!trackUnhandledRejections) { 22265 return; 22266 } 22267 22268 var at = array_indexOf(unhandledRejections, promise); 22269 if (at !== -1) { 22270 if (typeof process === "object" && typeof process.emit === "function") { 22271 Q.nextTick.runAfter(function () { 22272 var atReport = array_indexOf(reportedUnhandledRejections, promise); 22273 if (atReport !== -1) { 22274 process.emit("rejectionHandled", unhandledReasons[at], promise); 22275 reportedUnhandledRejections.splice(atReport, 1); 22276 } 22277 }); 22278 } 22279 unhandledRejections.splice(at, 1); 22280 unhandledReasons.splice(at, 1); 22281 } 22282 } 22283 22284 Q.resetUnhandledRejections = resetUnhandledRejections; 22285 22286 Q.getUnhandledReasons = function () { 22287 // Make a copy so that consumers can't interfere with our internal state. 22288 return unhandledReasons.slice(); 22289 }; 22290 22291 Q.stopUnhandledRejectionTracking = function () { 22292 resetUnhandledRejections(); 22293 trackUnhandledRejections = false; 22294 }; 22295 22296 resetUnhandledRejections(); 22297 22298 //// END UNHANDLED REJECTION TRACKING 22299 22300 /** 22301 * Constructs a rejected promise. 22302 * @param reason value describing the failure 22303 */ 22304 Q.reject = reject; 22305 function reject(reason) { 22306 var rejection = Promise({ 22307 "when": function (rejected) { 22308 // note that the error has been handled 22309 if (rejected) { 22310 untrackRejection(this); 22311 } 22312 return rejected ? rejected(reason) : this; 22313 } 22314 }, function fallback() { 22315 return this; 22316 }, function inspect() { 22317 return { state: "rejected", reason: reason }; 22318 }); 22319 22320 // Note that the reason has not been handled. 22321 trackRejection(rejection, reason); 22322 22323 return rejection; 22324 } 22325 22326 /** 22327 * Constructs a fulfilled promise for an immediate reference. 22328 * @param value immediate reference 22329 */ 22330 Q.fulfill = fulfill; 22331 function fulfill(value) { 22332 return Promise({ 22333 "when": function () { 22334 return value; 22335 }, 22336 "get": function (name) { 22337 return value[name]; 22338 }, 22339 "set": function (name, rhs) { 22340 value[name] = rhs; 22341 }, 22342 "delete": function (name) { 22343 delete value[name]; 22344 }, 22345 "post": function (name, args) { 22346 // Mark Miller proposes that post with no name should apply a 22347 // promised function. 22348 if (name === null || name === void 0) { 22349 return value.apply(void 0, args); 22350 } else { 22351 return value[name].apply(value, args); 22352 } 22353 }, 22354 "apply": function (thisp, args) { 22355 return value.apply(thisp, args); 22356 }, 22357 "keys": function () { 22358 return object_keys(value); 22359 } 22360 }, void 0, function inspect() { 22361 return { state: "fulfilled", value: value }; 22362 }); 22363 } 22364 22365 /** 22366 * Converts thenables to Q promises. 22367 * @param promise thenable promise 22368 * @returns a Q promise 22369 */ 22370 function coerce(promise) { 22371 var deferred = defer(); 22372 Q.nextTick(function () { 22373 try { 22374 promise.then(deferred.resolve, deferred.reject, deferred.notify); 22375 } catch (exception) { 22376 deferred.reject(exception); 22377 } 22378 }); 22379 return deferred.promise; 22380 } 22381 22382 /** 22383 * Annotates an object such that it will never be 22384 * transferred away from this process over any promise 22385 * communication channel. 22386 * @param object 22387 * @returns promise a wrapping of that object that 22388 * additionally responds to the "isDef" message 22389 * without a rejection. 22390 */ 22391 Q.master = master; 22392 function master(object) { 22393 return Promise({ 22394 "isDef": function () {} 22395 }, function fallback(op, args) { 22396 return dispatch(object, op, args); 22397 }, function () { 22398 return Q(object).inspect(); 22399 }); 22400 } 22401 22402 /** 22403 * Spreads the values of a promised array of arguments into the 22404 * fulfillment callback. 22405 * @param fulfilled callback that receives variadic arguments from the 22406 * promised array 22407 * @param rejected callback that receives the exception if the promise 22408 * is rejected. 22409 * @returns a promise for the return value or thrown exception of 22410 * either callback. 22411 */ 22412 Q.spread = spread; 22413 function spread(value, fulfilled, rejected) { 22414 return Q(value).spread(fulfilled, rejected); 22415 } 22416 22417 Promise.prototype.spread = function (fulfilled, rejected) { 22418 return this.all().then(function (array) { 22419 return fulfilled.apply(void 0, array); 22420 }, rejected); 22421 }; 22422 22423 /** 22424 * The async function is a decorator for generator functions, turning 22425 * them into asynchronous generators. Although generators are only part 22426 * of the newest ECMAScript 6 drafts, this code does not cause syntax 22427 * errors in older engines. This code should continue to work and will 22428 * in fact improve over time as the language improves. 22429 * 22430 * ES6 generators are currently part of V8 version 3.19 with the 22431 * --harmony-generators runtime flag enabled. SpiderMonkey has had them 22432 * for longer, but under an older Python-inspired form. This function 22433 * works on both kinds of generators. 22434 * 22435 * Decorates a generator function such that: 22436 * - it may yield promises 22437 * - execution will continue when that promise is fulfilled 22438 * - the value of the yield expression will be the fulfilled value 22439 * - it returns a promise for the return value (when the generator 22440 * stops iterating) 22441 * - the decorated function returns a promise for the return value 22442 * of the generator or the first rejected promise among those 22443 * yielded. 22444 * - if an error is thrown in the generator, it propagates through 22445 * every following yield until it is caught, or until it escapes 22446 * the generator function altogether, and is translated into a 22447 * rejection for the promise returned by the decorated generator. 22448 */ 22449 Q.async = async; 22450 function async(makeGenerator) { 22451 return function () { 22452 // when verb is "send", arg is a value 22453 // when verb is "throw", arg is an exception 22454 function continuer(verb, arg) { 22455 var result; 22456 22457 // Until V8 3.19 / Chromium 29 is released, SpiderMonkey is the only 22458 // engine that has a deployed base of browsers that support generators. 22459 // However, SM's generators use the Python-inspired semantics of 22460 // outdated ES6 drafts. We would like to support ES6, but we'd also 22461 // like to make it possible to use generators in deployed browsers, so 22462 // we also support Python-style generators. At some point we can remove 22463 // this block. 22464 22465 if (typeof StopIteration === "undefined") { 22466 // ES6 Generators 22467 try { 22468 result = generator[verb](arg); 22469 } catch (exception) { 22470 return reject(exception); 22471 } 22472 if (result.done) { 22473 return Q(result.value); 22474 } else { 22475 return when(result.value, callback, errback); 22476 } 22477 } else { 22478 // SpiderMonkey Generators 22479 // FIXME: Remove this case when SM does ES6 generators. 22480 try { 22481 result = generator[verb](arg); 22482 } catch (exception) { 22483 if (isStopIteration(exception)) { 22484 return Q(exception.value); 22485 } else { 22486 return reject(exception); 22487 } 22488 } 22489 return when(result, callback, errback); 22490 } 22491 } 22492 var generator = makeGenerator.apply(this, arguments); 22493 var callback = continuer.bind(continuer, "next"); 22494 var errback = continuer.bind(continuer, "throw"); 22495 return callback(); 22496 }; 22497 } 22498 22499 /** 22500 * The spawn function is a small wrapper around async that immediately 22501 * calls the generator and also ends the promise chain, so that any 22502 * unhandled errors are thrown instead of forwarded to the error 22503 * handler. This is useful because it's extremely common to run 22504 * generators at the top-level to work with libraries. 22505 */ 22506 Q.spawn = spawn; 22507 function spawn(makeGenerator) { 22508 Q.done(Q.async(makeGenerator)()); 22509 } 22510 22511 // FIXME: Remove this interface once ES6 generators are in SpiderMonkey. 22512 /** 22513 * Throws a ReturnValue exception to stop an asynchronous generator. 22514 * 22515 * This interface is a stop-gap measure to support generator return 22516 * values in older Firefox/SpiderMonkey. In browsers that support ES6 22517 * generators like Chromium 29, just use "return" in your generator 22518 * functions. 22519 * 22520 * @param value the return value for the surrounding generator 22521 * @throws ReturnValue exception with the value. 22522 * @example 22523 * // ES6 style 22524 * Q.async(function* () { 22525 * var foo = yield getFooPromise(); 22526 * var bar = yield getBarPromise(); 22527 * return foo + bar; 22528 * }) 22529 * // Older SpiderMonkey style 22530 * Q.async(function () { 22531 * var foo = yield getFooPromise(); 22532 * var bar = yield getBarPromise(); 22533 * Q.return(foo + bar); 22534 * }) 22535 */ 22536 Q["return"] = _return; 22537 function _return(value) { 22538 throw new QReturnValue(value); 22539 } 22540 22541 /** 22542 * The promised function decorator ensures that any promise arguments 22543 * are settled and passed as values (`this` is also settled and passed 22544 * as a value). It will also ensure that the result of a function is 22545 * always a promise. 22546 * 22547 * @example 22548 * var add = Q.promised(function (a, b) { 22549 * return a + b; 22550 * }); 22551 * add(Q(a), Q(B)); 22552 * 22553 * @param {function} callback The function to decorate 22554 * @returns {function} a function that has been decorated. 22555 */ 22556 Q.promised = promised; 22557 function promised(callback) { 22558 return function () { 22559 return spread([this, all(arguments)], function (self, args) { 22560 return callback.apply(self, args); 22561 }); 22562 }; 22563 } 22564 22565 /** 22566 * sends a message to a value in a future turn 22567 * @param object* the recipient 22568 * @param op the name of the message operation, e.g., "when", 22569 * @param args further arguments to be forwarded to the operation 22570 * @returns result {Promise} a promise for the result of the operation 22571 */ 22572 Q.dispatch = dispatch; 22573 function dispatch(object, op, args) { 22574 return Q(object).dispatch(op, args); 22575 } 22576 22577 Promise.prototype.dispatch = function (op, args) { 22578 var self = this; 22579 var deferred = defer(); 22580 Q.nextTick(function () { 22581 self.promiseDispatch(deferred.resolve, op, args); 22582 }); 22583 return deferred.promise; 22584 }; 22585 22586 /** 22587 * Gets the value of a property in a future turn. 22588 * @param object promise or immediate reference for target object 22589 * @param name name of property to get 22590 * @return promise for the property value 22591 */ 22592 Q.get = function (object, key) { 22593 return Q(object).dispatch("get", [key]); 22594 }; 22595 22596 Promise.prototype.get = function (key) { 22597 return this.dispatch("get", [key]); 22598 }; 22599 22600 /** 22601 * Sets the value of a property in a future turn. 22602 * @param object promise or immediate reference for object object 22603 * @param name name of property to set 22604 * @param value new value of property 22605 * @return promise for the return value 22606 */ 22607 Q.set = function (object, key, value) { 22608 return Q(object).dispatch("set", [key, value]); 22609 }; 22610 22611 Promise.prototype.set = function (key, value) { 22612 return this.dispatch("set", [key, value]); 22613 }; 22614 22615 /** 22616 * Deletes a property in a future turn. 22617 * @param object promise or immediate reference for target object 22618 * @param name name of property to delete 22619 * @return promise for the return value 22620 */ 22621 Q.del = // XXX legacy 22622 Q["delete"] = function (object, key) { 22623 return Q(object).dispatch("delete", [key]); 22624 }; 22625 22626 Promise.prototype.del = // XXX legacy 22627 Promise.prototype["delete"] = function (key) { 22628 return this.dispatch("delete", [key]); 22629 }; 22630 22631 /** 22632 * Invokes a method in a future turn. 22633 * @param object promise or immediate reference for target object 22634 * @param name name of method to invoke 22635 * @param value a value to post, typically an array of 22636 * invocation arguments for promises that 22637 * are ultimately backed with `resolve` values, 22638 * as opposed to those backed with URLs 22639 * wherein the posted value can be any 22640 * JSON serializable object. 22641 * @return promise for the return value 22642 */ 22643 // bound locally because it is used by other methods 22644 Q.mapply = // XXX As proposed by "Redsandro" 22645 Q.post = function (object, name, args) { 22646 return Q(object).dispatch("post", [name, args]); 22647 }; 22648 22649 Promise.prototype.mapply = // XXX As proposed by "Redsandro" 22650 Promise.prototype.post = function (name, args) { 22651 return this.dispatch("post", [name, args]); 22652 }; 22653 22654 /** 22655 * Invokes a method in a future turn. 22656 * @param object promise or immediate reference for target object 22657 * @param name name of method to invoke 22658 * @param ...args array of invocation arguments 22659 * @return promise for the return value 22660 */ 22661 Q.send = // XXX Mark Miller's proposed parlance 22662 Q.mcall = // XXX As proposed by "Redsandro" 22663 Q.invoke = function (object, name /*...args*/) { 22664 return Q(object).dispatch("post", [name, array_slice(arguments, 2)]); 22665 }; 22666 22667 Promise.prototype.send = // XXX Mark Miller's proposed parlance 22668 Promise.prototype.mcall = // XXX As proposed by "Redsandro" 22669 Promise.prototype.invoke = function (name /*...args*/) { 22670 return this.dispatch("post", [name, array_slice(arguments, 1)]); 22671 }; 22672 22673 /** 22674 * Applies the promised function in a future turn. 22675 * @param object promise or immediate reference for target function 22676 * @param args array of application arguments 22677 */ 22678 Q.fapply = function (object, args) { 22679 return Q(object).dispatch("apply", [void 0, args]); 22680 }; 22681 22682 Promise.prototype.fapply = function (args) { 22683 return this.dispatch("apply", [void 0, args]); 22684 }; 22685 22686 /** 22687 * Calls the promised function in a future turn. 22688 * @param object promise or immediate reference for target function 22689 * @param ...args array of application arguments 22690 */ 22691 Q["try"] = 22692 Q.fcall = function (object /* ...args*/) { 22693 return Q(object).dispatch("apply", [void 0, array_slice(arguments, 1)]); 22694 }; 22695 22696 Promise.prototype.fcall = function (/*...args*/) { 22697 return this.dispatch("apply", [void 0, array_slice(arguments)]); 22698 }; 22699 22700 /** 22701 * Binds the promised function, transforming return values into a fulfilled 22702 * promise and thrown errors into a rejected one. 22703 * @param object promise or immediate reference for target function 22704 * @param ...args array of application arguments 22705 */ 22706 Q.fbind = function (object /*...args*/) { 22707 var promise = Q(object); 22708 var args = array_slice(arguments, 1); 22709 return function fbound() { 22710 return promise.dispatch("apply", [ 22711 this, 22712 args.concat(array_slice(arguments)) 22713 ]); 22714 }; 22715 }; 22716 Promise.prototype.fbind = function (/*...args*/) { 22717 var promise = this; 22718 var args = array_slice(arguments); 22719 return function fbound() { 22720 return promise.dispatch("apply", [ 22721 this, 22722 args.concat(array_slice(arguments)) 22723 ]); 22724 }; 22725 }; 22726 22727 /** 22728 * Requests the names of the owned properties of a promised 22729 * object in a future turn. 22730 * @param object promise or immediate reference for target object 22731 * @return promise for the keys of the eventually settled object 22732 */ 22733 Q.keys = function (object) { 22734 return Q(object).dispatch("keys", []); 22735 }; 22736 22737 Promise.prototype.keys = function () { 22738 return this.dispatch("keys", []); 22739 }; 22740 22741 /** 22742 * Turns an array of promises into a promise for an array. If any of 22743 * the promises gets rejected, the whole array is rejected immediately. 22744 * @param {Array*} an array (or promise for an array) of values (or 22745 * promises for values) 22746 * @returns a promise for an array of the corresponding values 22747 */ 22748 // By Mark Miller 22749 // http://wiki.ecmascript.org/doku.php?id=strawman:concurrency&rev=1308776521#allfulfilled 22750 Q.all = all; 22751 function all(promises) { 22752 return when(promises, function (promises) { 22753 var pendingCount = 0; 22754 var deferred = defer(); 22755 array_reduce(promises, function (undefined, promise, index) { 22756 var snapshot; 22757 if ( 22758 isPromise(promise) && 22759 (snapshot = promise.inspect()).state === "fulfilled" 22760 ) { 22761 promises[index] = snapshot.value; 22762 } else { 22763 ++pendingCount; 22764 when( 22765 promise, 22766 function (value) { 22767 promises[index] = value; 22768 if (--pendingCount === 0) { 22769 deferred.resolve(promises); 22770 } 22771 }, 22772 deferred.reject, 22773 function (progress) { 22774 deferred.notify({ index: index, value: progress }); 22775 } 22776 ); 22777 } 22778 }, void 0); 22779 if (pendingCount === 0) { 22780 deferred.resolve(promises); 22781 } 22782 return deferred.promise; 22783 }); 22784 } 22785 22786 Promise.prototype.all = function () { 22787 return all(this); 22788 }; 22789 22790 /** 22791 * Returns the first resolved promise of an array. Prior rejected promises are 22792 * ignored. Rejects only if all promises are rejected. 22793 * @param {Array*} an array containing values or promises for values 22794 * @returns a promise fulfilled with the value of the first resolved promise, 22795 * or a rejected promise if all promises are rejected. 22796 */ 22797 Q.any = any; 22798 22799 function any(promises) { 22800 if (promises.length === 0) { 22801 return Q.resolve(); 22802 } 22803 22804 var deferred = Q.defer(); 22805 var pendingCount = 0; 22806 array_reduce(promises, function (prev, current, index) { 22807 var promise = promises[index]; 22808 22809 pendingCount++; 22810 22811 when(promise, onFulfilled, onRejected, onProgress); 22812 function onFulfilled(result) { 22813 deferred.resolve(result); 22814 } 22815 function onRejected() { 22816 pendingCount--; 22817 if (pendingCount === 0) { 22818 deferred.reject(new Error( 22819 "Can't get fulfillment value from any promise, all " + 22820 "promises were rejected." 22821 )); 22822 } 22823 } 22824 function onProgress(progress) { 22825 deferred.notify({ 22826 index: index, 22827 value: progress 22828 }); 22829 } 22830 }, undefined); 22831 22832 return deferred.promise; 22833 } 22834 22835 Promise.prototype.any = function () { 22836 return any(this); 22837 }; 22838 22839 /** 22840 * Waits for all promises to be settled, either fulfilled or 22841 * rejected. This is distinct from `all` since that would stop 22842 * waiting at the first rejection. The promise returned by 22843 * `allResolved` will never be rejected. 22844 * @param promises a promise for an array (or an array) of promises 22845 * (or values) 22846 * @return a promise for an array of promises 22847 */ 22848 Q.allResolved = deprecate(allResolved, "allResolved", "allSettled"); 22849 function allResolved(promises) { 22850 return when(promises, function (promises) { 22851 promises = array_map(promises, Q); 22852 return when(all(array_map(promises, function (promise) { 22853 return when(promise, noop, noop); 22854 })), function () { 22855 return promises; 22856 }); 22857 }); 22858 } 22859 22860 Promise.prototype.allResolved = function () { 22861 return allResolved(this); 22862 }; 22863 22864 /** 22865 * @see Promise#allSettled 22866 */ 22867 Q.allSettled = allSettled; 22868 function allSettled(promises) { 22869 return Q(promises).allSettled(); 22870 } 22871 22872 /** 22873 * Turns an array of promises into a promise for an array of their states (as 22874 * returned by `inspect`) when they have all settled. 22875 * @param {Array[Any*]} values an array (or promise for an array) of values (or 22876 * promises for values) 22877 * @returns {Array[State]} an array of states for the respective values. 22878 */ 22879 Promise.prototype.allSettled = function () { 22880 return this.then(function (promises) { 22881 return all(array_map(promises, function (promise) { 22882 promise = Q(promise); 22883 function regardless() { 22884 return promise.inspect(); 22885 } 22886 return promise.then(regardless, regardless); 22887 })); 22888 }); 22889 }; 22890 22891 /** 22892 * Captures the failure of a promise, giving an oportunity to recover 22893 * with a callback. If the given promise is fulfilled, the returned 22894 * promise is fulfilled. 22895 * @param {Any*} promise for something 22896 * @param {Function} callback to fulfill the returned promise if the 22897 * given promise is rejected 22898 * @returns a promise for the return value of the callback 22899 */ 22900 Q.fail = // XXX legacy 22901 Q["catch"] = function (object, rejected) { 22902 return Q(object).then(void 0, rejected); 22903 }; 22904 22905 Promise.prototype.fail = // XXX legacy 22906 Promise.prototype["catch"] = function (rejected) { 22907 return this.then(void 0, rejected); 22908 }; 22909 22910 /** 22911 * Attaches a listener that can respond to progress notifications from a 22912 * promise's originating deferred. This listener receives the exact arguments 22913 * passed to ``deferred.notify``. 22914 * @param {Any*} promise for something 22915 * @param {Function} callback to receive any progress notifications 22916 * @returns the given promise, unchanged 22917 */ 22918 Q.progress = progress; 22919 function progress(object, progressed) { 22920 return Q(object).then(void 0, void 0, progressed); 22921 } 22922 22923 Promise.prototype.progress = function (progressed) { 22924 return this.then(void 0, void 0, progressed); 22925 }; 22926 22927 /** 22928 * Provides an opportunity to observe the settling of a promise, 22929 * regardless of whether the promise is fulfilled or rejected. Forwards 22930 * the resolution to the returned promise when the callback is done. 22931 * The callback can return a promise to defer completion. 22932 * @param {Any*} promise 22933 * @param {Function} callback to observe the resolution of the given 22934 * promise, takes no arguments. 22935 * @returns a promise for the resolution of the given promise when 22936 * ``fin`` is done. 22937 */ 22938 Q.fin = // XXX legacy 22939 Q["finally"] = function (object, callback) { 22940 return Q(object)["finally"](callback); 22941 }; 22942 22943 Promise.prototype.fin = // XXX legacy 22944 Promise.prototype["finally"] = function (callback) { 22945 callback = Q(callback); 22946 return this.then(function (value) { 22947 return callback.fcall().then(function () { 22948 return value; 22949 }); 22950 }, function (reason) { 22951 // TODO attempt to recycle the rejection with "this". 22952 return callback.fcall().then(function () { 22953 throw reason; 22954 }); 22955 }); 22956 }; 22957 22958 /** 22959 * Terminates a chain of promises, forcing rejections to be 22960 * thrown as exceptions. 22961 * @param {Any*} promise at the end of a chain of promises 22962 * @returns nothing 22963 */ 22964 Q.done = function (object, fulfilled, rejected, progress) { 22965 return Q(object).done(fulfilled, rejected, progress); 22966 }; 22967 22968 Promise.prototype.done = function (fulfilled, rejected, progress) { 22969 var onUnhandledError = function (error) { 22970 // forward to a future turn so that ``when`` 22971 // does not catch it and turn it into a rejection. 22972 Q.nextTick(function () { 22973 makeStackTraceLong(error, promise); 22974 if (Q.onerror) { 22975 Q.onerror(error); 22976 } else { 22977 throw error; 22978 } 22979 }); 22980 }; 22981 22982 // Avoid unnecessary `nextTick`ing via an unnecessary `when`. 22983 var promise = fulfilled || rejected || progress ? 22984 this.then(fulfilled, rejected, progress) : 22985 this; 22986 22987 if (typeof process === "object" && process && process.domain) { 22988 onUnhandledError = process.domain.bind(onUnhandledError); 22989 } 22990 22991 promise.then(void 0, onUnhandledError); 22992 }; 22993 22994 /** 22995 * Causes a promise to be rejected if it does not get fulfilled before 22996 * some milliseconds time out. 22997 * @param {Any*} promise 22998 * @param {Number} milliseconds timeout 22999 * @param {Any*} custom error message or Error object (optional) 23000 * @returns a promise for the resolution of the given promise if it is 23001 * fulfilled before the timeout, otherwise rejected. 23002 */ 23003 Q.timeout = function (object, ms, error) { 23004 return Q(object).timeout(ms, error); 23005 }; 23006 23007 Promise.prototype.timeout = function (ms, error) { 23008 var deferred = defer(); 23009 var timeoutId = setTimeout(function () { 23010 if (!error || "string" === typeof error) { 23011 error = new Error(error || "Timed out after " + ms + " ms"); 23012 error.code = "ETIMEDOUT"; 23013 } 23014 deferred.reject(error); 23015 }, ms); 23016 23017 this.then(function (value) { 23018 clearTimeout(timeoutId); 23019 deferred.resolve(value); 23020 }, function (exception) { 23021 clearTimeout(timeoutId); 23022 deferred.reject(exception); 23023 }, deferred.notify); 23024 23025 return deferred.promise; 23026 }; 23027 23028 /** 23029 * Returns a promise for the given value (or promised value), some 23030 * milliseconds after it resolved. Passes rejections immediately. 23031 * @param {Any*} promise 23032 * @param {Number} milliseconds 23033 * @returns a promise for the resolution of the given promise after milliseconds 23034 * time has elapsed since the resolution of the given promise. 23035 * If the given promise rejects, that is passed immediately. 23036 */ 23037 Q.delay = function (object, timeout) { 23038 if (timeout === void 0) { 23039 timeout = object; 23040 object = void 0; 23041 } 23042 return Q(object).delay(timeout); 23043 }; 23044 23045 Promise.prototype.delay = function (timeout) { 23046 return this.then(function (value) { 23047 var deferred = defer(); 23048 setTimeout(function () { 23049 deferred.resolve(value); 23050 }, timeout); 23051 return deferred.promise; 23052 }); 23053 }; 23054 23055 /** 23056 * Passes a continuation to a Node function, which is called with the given 23057 * arguments provided as an array, and returns a promise. 23058 * 23059 * Q.nfapply(FS.readFile, [__filename]) 23060 * .then(function (content) { 23061 * }) 23062 * 23063 */ 23064 Q.nfapply = function (callback, args) { 23065 return Q(callback).nfapply(args); 23066 }; 23067 23068 Promise.prototype.nfapply = function (args) { 23069 var deferred = defer(); 23070 var nodeArgs = array_slice(args); 23071 nodeArgs.push(deferred.makeNodeResolver()); 23072 this.fapply(nodeArgs).fail(deferred.reject); 23073 return deferred.promise; 23074 }; 23075 23076 /** 23077 * Passes a continuation to a Node function, which is called with the given 23078 * arguments provided individually, and returns a promise. 23079 * @example 23080 * Q.nfcall(FS.readFile, __filename) 23081 * .then(function (content) { 23082 * }) 23083 * 23084 */ 23085 Q.nfcall = function (callback /*...args*/) { 23086 var args = array_slice(arguments, 1); 23087 return Q(callback).nfapply(args); 23088 }; 23089 23090 Promise.prototype.nfcall = function (/*...args*/) { 23091 var nodeArgs = array_slice(arguments); 23092 var deferred = defer(); 23093 nodeArgs.push(deferred.makeNodeResolver()); 23094 this.fapply(nodeArgs).fail(deferred.reject); 23095 return deferred.promise; 23096 }; 23097 23098 /** 23099 * Wraps a NodeJS continuation passing function and returns an equivalent 23100 * version that returns a promise. 23101 * @example 23102 * Q.nfbind(FS.readFile, __filename)("utf-8") 23103 * .then(console.log) 23104 * .done() 23105 */ 23106 Q.nfbind = 23107 Q.denodeify = function (callback /*...args*/) { 23108 var baseArgs = array_slice(arguments, 1); 23109 return function () { 23110 var nodeArgs = baseArgs.concat(array_slice(arguments)); 23111 var deferred = defer(); 23112 nodeArgs.push(deferred.makeNodeResolver()); 23113 Q(callback).fapply(nodeArgs).fail(deferred.reject); 23114 return deferred.promise; 23115 }; 23116 }; 23117 23118 Promise.prototype.nfbind = 23119 Promise.prototype.denodeify = function (/*...args*/) { 23120 var args = array_slice(arguments); 23121 args.unshift(this); 23122 return Q.denodeify.apply(void 0, args); 23123 }; 23124 23125 Q.nbind = function (callback, thisp /*...args*/) { 23126 var baseArgs = array_slice(arguments, 2); 23127 return function () { 23128 var nodeArgs = baseArgs.concat(array_slice(arguments)); 23129 var deferred = defer(); 23130 nodeArgs.push(deferred.makeNodeResolver()); 23131 function bound() { 23132 return callback.apply(thisp, arguments); 23133 } 23134 Q(bound).fapply(nodeArgs).fail(deferred.reject); 23135 return deferred.promise; 23136 }; 23137 }; 23138 23139 Promise.prototype.nbind = function (/*thisp, ...args*/) { 23140 var args = array_slice(arguments, 0); 23141 args.unshift(this); 23142 return Q.nbind.apply(void 0, args); 23143 }; 23144 23145 /** 23146 * Calls a method of a Node-style object that accepts a Node-style 23147 * callback with a given array of arguments, plus a provided callback. 23148 * @param object an object that has the named method 23149 * @param {String} name name of the method of object 23150 * @param {Array} args arguments to pass to the method; the callback 23151 * will be provided by Q and appended to these arguments. 23152 * @returns a promise for the value or error 23153 */ 23154 Q.nmapply = // XXX As proposed by "Redsandro" 23155 Q.npost = function (object, name, args) { 23156 return Q(object).npost(name, args); 23157 }; 23158 23159 Promise.prototype.nmapply = // XXX As proposed by "Redsandro" 23160 Promise.prototype.npost = function (name, args) { 23161 var nodeArgs = array_slice(args || []); 23162 var deferred = defer(); 23163 nodeArgs.push(deferred.makeNodeResolver()); 23164 this.dispatch("post", [name, nodeArgs]).fail(deferred.reject); 23165 return deferred.promise; 23166 }; 23167 23168 /** 23169 * Calls a method of a Node-style object that accepts a Node-style 23170 * callback, forwarding the given variadic arguments, plus a provided 23171 * callback argument. 23172 * @param object an object that has the named method 23173 * @param {String} name name of the method of object 23174 * @param ...args arguments to pass to the method; the callback will 23175 * be provided by Q and appended to these arguments. 23176 * @returns a promise for the value or error 23177 */ 23178 Q.nsend = // XXX Based on Mark Miller's proposed "send" 23179 Q.nmcall = // XXX Based on "Redsandro's" proposal 23180 Q.ninvoke = function (object, name /*...args*/) { 23181 var nodeArgs = array_slice(arguments, 2); 23182 var deferred = defer(); 23183 nodeArgs.push(deferred.makeNodeResolver()); 23184 Q(object).dispatch("post", [name, nodeArgs]).fail(deferred.reject); 23185 return deferred.promise; 23186 }; 23187 23188 Promise.prototype.nsend = // XXX Based on Mark Miller's proposed "send" 23189 Promise.prototype.nmcall = // XXX Based on "Redsandro's" proposal 23190 Promise.prototype.ninvoke = function (name /*...args*/) { 23191 var nodeArgs = array_slice(arguments, 1); 23192 var deferred = defer(); 23193 nodeArgs.push(deferred.makeNodeResolver()); 23194 this.dispatch("post", [name, nodeArgs]).fail(deferred.reject); 23195 return deferred.promise; 23196 }; 23197 23198 /** 23199 * If a function would like to support both Node continuation-passing-style and 23200 * promise-returning-style, it can end its internal promise chain with 23201 * `nodeify(nodeback)`, forwarding the optional nodeback argument. If the user 23202 * elects to use a nodeback, the result will be sent there. If they do not 23203 * pass a nodeback, they will receive the result promise. 23204 * @param object a result (or a promise for a result) 23205 * @param {Function} nodeback a Node.js-style callback 23206 * @returns either the promise or nothing 23207 */ 23208 Q.nodeify = nodeify; 23209 function nodeify(object, nodeback) { 23210 return Q(object).nodeify(nodeback); 23211 } 23212 23213 Promise.prototype.nodeify = function (nodeback) { 23214 if (nodeback) { 23215 this.then(function (value) { 23216 Q.nextTick(function () { 23217 nodeback(null, value); 23218 }); 23219 }, function (error) { 23220 Q.nextTick(function () { 23221 nodeback(error); 23222 }); 23223 }); 23224 } else { 23225 return this; 23226 } 23227 }; 23228 23229 Q.noConflict = function() { 23230 throw new Error("Q.noConflict only works when Q is used as a global"); 23231 }; 23232 23233 // All code before this point will be filtered from stack traces. 23234 var qEndingLine = captureLine(); 23235 23236 return Q; 23237 23238 }); 23239 23240 }).call(this,require('_process')) 23241 //# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/q/q.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":["// vim:ts=4:sts=4:sw=4:\n/*!\n *\n * Copyright 2009-2012 Kris Kowal under the terms of the MIT\n * license found at http://github.com/kriskowal/q/raw/master/LICENSE\n *\n * With parts by Tyler Close\n * Copyright 2007-2009 Tyler Close under the terms of the MIT X license found\n * at http://www.opensource.org/licenses/mit-license.html\n * Forked at ref_send.js version: 2009-05-11\n *\n * With parts by Mark Miller\n * Copyright (C) 2011 Google Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\n(function (definition) {\n    \"use strict\";\n\n    // This file will function properly as a <script> tag, or a module\n    // using CommonJS and NodeJS or RequireJS module formats.  In\n    // Common/Node/RequireJS, the module exports the Q API and when\n    // executed as a simple <script>, it creates a Q global instead.\n\n    // Montage Require\n    if (typeof bootstrap === \"function\") {\n        bootstrap(\"promise\", definition);\n\n    // CommonJS\n    } else if (typeof exports === \"object\" && typeof module === \"object\") {\n        module.exports = definition();\n\n    // RequireJS\n    } else if (typeof define === \"function\" && define.amd) {\n        define(definition);\n\n    // SES (Secure EcmaScript)\n    } else if (typeof ses !== \"undefined\") {\n        if (!ses.ok()) {\n            return;\n        } else {\n            ses.makeQ = definition;\n        }\n\n    // <script>\n    } else if (typeof window !== \"undefined\" || typeof self !== \"undefined\") {\n        // Prefer window over self for add-on scripts. Use self for\n        // non-windowed contexts.\n        var global = typeof window !== \"undefined\" ? window : self;\n\n        // Get the `window` object, save the previous Q global\n        // and initialize Q as a global.\n        var previousQ = global.Q;\n        global.Q = definition();\n\n        // Add a noConflict function so Q can be removed from the\n        // global namespace.\n        global.Q.noConflict = function () {\n            global.Q = previousQ;\n            return this;\n        };\n\n    } else {\n        throw new Error(\"This environment was not anticipated by Q. Please file a bug.\");\n    }\n\n})(function () {\n\"use strict\";\n\nvar hasStacks = false;\ntry {\n    throw new Error();\n} catch (e) {\n    hasStacks = !!e.stack;\n}\n\n// All code after this point will be filtered from stack traces reported\n// by Q.\nvar qStartingLine = captureLine();\nvar qFileName;\n\n// shims\n\n// used for fallback in \"allResolved\"\nvar noop = function () {};\n\n// Use the fastest possible means to execute a task in a future turn\n// of the event loop.\nvar nextTick =(function () {\n    // linked list of tasks (single, with head node)\n    var head = {task: void 0, next: null};\n    var tail = head;\n    var flushing = false;\n    var requestTick = void 0;\n    var isNodeJS = false;\n    // queue for late tasks, used by unhandled rejection tracking\n    var laterQueue = [];\n\n    function flush() {\n        /* jshint loopfunc: true */\n        var task, domain;\n\n        while (head.next) {\n            head = head.next;\n            task = head.task;\n            head.task = void 0;\n            domain = head.domain;\n\n            if (domain) {\n                head.domain = void 0;\n                domain.enter();\n            }\n            runSingle(task, domain);\n\n        }\n        while (laterQueue.length) {\n            task = laterQueue.pop();\n            runSingle(task);\n        }\n        flushing = false;\n    }\n    // runs a single function in the async queue\n    function runSingle(task, domain) {\n        try {\n            task();\n\n        } catch (e) {\n            if (isNodeJS) {\n                // In node, uncaught exceptions are considered fatal errors.\n                // Re-throw them synchronously to interrupt flushing!\n\n                // Ensure continuation if the uncaught exception is suppressed\n                // listening \"uncaughtException\" events (as domains does).\n                // Continue in next event to avoid tick recursion.\n                if (domain) {\n                    domain.exit();\n                }\n                setTimeout(flush, 0);\n                if (domain) {\n                    domain.enter();\n                }\n\n                throw e;\n\n            } else {\n                // In browsers, uncaught exceptions are not fatal.\n                // Re-throw them asynchronously to avoid slow-downs.\n                setTimeout(function () {\n                    throw e;\n                }, 0);\n            }\n        }\n\n        if (domain) {\n            domain.exit();\n        }\n    }\n\n    nextTick = function (task) {\n        tail = tail.next = {\n            task: task,\n            domain: isNodeJS && process.domain,\n            next: null\n        };\n\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n\n    if (typeof process === \"object\" &&\n        process.toString() === \"[object process]\" && process.nextTick) {\n        // Ensure Q is in a real Node environment, with a `process.nextTick`.\n        // To see through fake Node environments:\n        // * Mocha test runner - exposes a `process` global without a `nextTick`\n        // * Browserify - exposes a `process.nexTick` function that uses\n        //   `setTimeout`. In this case `setImmediate` is preferred because\n        //    it is faster. Browserify's `process.toString()` yields\n        //   \"[object Object]\", while in a real Node environment\n        //   `process.nextTick()` yields \"[object process]\".\n        isNodeJS = true;\n\n        requestTick = function () {\n            process.nextTick(flush);\n        };\n\n    } else if (typeof setImmediate === \"function\") {\n        // In IE10, Node.js 0.9+, or https://github.com/NobleJS/setImmediate\n        if (typeof window !== \"undefined\") {\n            requestTick = setImmediate.bind(window, flush);\n        } else {\n            requestTick = function () {\n                setImmediate(flush);\n            };\n        }\n\n    } else if (typeof MessageChannel !== \"undefined\") {\n        // modern browsers\n        // http://www.nonblocking.io/2011/06/windownexttick.html\n        var channel = new MessageChannel();\n        // At least Safari Version 6.0.5 (8536.30.1) intermittently cannot create\n        // working message ports the first time a page loads.\n        channel.port1.onmessage = function () {\n            requestTick = requestPortTick;\n            channel.port1.onmessage = flush;\n            flush();\n        };\n        var requestPortTick = function () {\n            // Opera requires us to provide a message payload, regardless of\n            // whether we use it.\n            channel.port2.postMessage(0);\n        };\n        requestTick = function () {\n            setTimeout(flush, 0);\n            requestPortTick();\n        };\n\n    } else {\n        // old browsers\n        requestTick = function () {\n            setTimeout(flush, 0);\n        };\n    }\n    // runs a task after all other tasks have been run\n    // this is useful for unhandled rejection tracking that needs to happen\n    // after all `then`d tasks have been run.\n    nextTick.runAfter = function (task) {\n        laterQueue.push(task);\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n    return nextTick;\n})();\n\n// Attempt to make generics safe in the face of downstream\n// modifications.\n// There is no situation where this is necessary.\n// If you need a security guarantee, these primordials need to be\n// deeply frozen anyway, and if you don’t need a security guarantee,\n// this is just plain paranoid.\n// However, this **might** have the nice side-effect of reducing the size of\n// the minified code by reducing x.call() to merely x()\n// See Mark Miller’s explanation of what this does.\n// http://wiki.ecmascript.org/doku.php?id=conventions:safe_meta_programming\nvar call = Function.call;\nfunction uncurryThis(f) {\n    return function () {\n        return call.apply(f, arguments);\n    };\n}\n// This is equivalent, but slower:\n// uncurryThis = Function_bind.bind(Function_bind.call);\n// http://jsperf.com/uncurrythis\n\nvar array_slice = uncurryThis(Array.prototype.slice);\n\nvar array_reduce = uncurryThis(\n    Array.prototype.reduce || function (callback, basis) {\n        var index = 0,\n            length = this.length;\n        // concerning the initial value, if one is not provided\n        if (arguments.length === 1) {\n            // seek to the first value in the array, accounting\n            // for the possibility that is is a sparse array\n            do {\n                if (index in this) {\n                    basis = this[index++];\n                    break;\n                }\n                if (++index >= length) {\n                    throw new TypeError();\n                }\n            } while (1);\n        }\n        // reduce\n        for (; index < length; index++) {\n            // account for the possibility that the array is sparse\n            if (index in this) {\n                basis = callback(basis, this[index], index);\n            }\n        }\n        return basis;\n    }\n);\n\nvar array_indexOf = uncurryThis(\n    Array.prototype.indexOf || function (value) {\n        // not a very good shim, but good enough for our one use of it\n        for (var i = 0; i < this.length; i++) {\n            if (this[i] === value) {\n                return i;\n            }\n        }\n        return -1;\n    }\n);\n\nvar array_map = uncurryThis(\n    Array.prototype.map || function (callback, thisp) {\n        var self = this;\n        var collect = [];\n        array_reduce(self, function (undefined, value, index) {\n            collect.push(callback.call(thisp, value, index, self));\n        }, void 0);\n        return collect;\n    }\n);\n\nvar object_create = Object.create || function (prototype) {\n    function Type() { }\n    Type.prototype = prototype;\n    return new Type();\n};\n\nvar object_hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty);\n\nvar object_keys = Object.keys || function (object) {\n    var keys = [];\n    for (var key in object) {\n        if (object_hasOwnProperty(object, key)) {\n            keys.push(key);\n        }\n    }\n    return keys;\n};\n\nvar object_toString = uncurryThis(Object.prototype.toString);\n\nfunction isObject(value) {\n    return value === Object(value);\n}\n\n// generator related shims\n\n// FIXME: Remove this function once ES6 generators are in SpiderMonkey.\nfunction isStopIteration(exception) {\n    return (\n        object_toString(exception) === \"[object StopIteration]\" ||\n        exception instanceof QReturnValue\n    );\n}\n\n// FIXME: Remove this helper and Q.return once ES6 generators are in\n// SpiderMonkey.\nvar QReturnValue;\nif (typeof ReturnValue !== \"undefined\") {\n    QReturnValue = ReturnValue;\n} else {\n    QReturnValue = function (value) {\n        this.value = value;\n    };\n}\n\n// long stack traces\n\nvar STACK_JUMP_SEPARATOR = \"From previous event:\";\n\nfunction makeStackTraceLong(error, promise) {\n    // If possible, transform the error stack trace by removing Node and Q\n    // cruft, then concatenating with the stack trace of `promise`. See #57.\n    if (hasStacks &&\n        promise.stack &&\n        typeof error === \"object\" &&\n        error !== null &&\n        error.stack &&\n        error.stack.indexOf(STACK_JUMP_SEPARATOR) === -1\n    ) {\n        var stacks = [];\n        for (var p = promise; !!p; p = p.source) {\n            if (p.stack) {\n                stacks.unshift(p.stack);\n            }\n        }\n        stacks.unshift(error.stack);\n\n        var concatedStacks = stacks.join(\"\\n\" + STACK_JUMP_SEPARATOR + \"\\n\");\n        error.stack = filterStackString(concatedStacks);\n    }\n}\n\nfunction filterStackString(stackString) {\n    var lines = stackString.split(\"\\n\");\n    var desiredLines = [];\n    for (var i = 0; i < lines.length; ++i) {\n        var line = lines[i];\n\n        if (!isInternalFrame(line) && !isNodeFrame(line) && line) {\n            desiredLines.push(line);\n        }\n    }\n    return desiredLines.join(\"\\n\");\n}\n\nfunction isNodeFrame(stackLine) {\n    return stackLine.indexOf(\"(module.js:\") !== -1 ||\n           stackLine.indexOf(\"(node.js:\") !== -1;\n}\n\nfunction getFileNameAndLineNumber(stackLine) {\n    // Named functions: \"at functionName (filename:lineNumber:columnNumber)\"\n    // In IE10 function name can have spaces (\"Anonymous function\") O_o\n    var attempt1 = /at .+ \\((.+):(\\d+):(?:\\d+)\\)$/.exec(stackLine);\n    if (attempt1) {\n        return [attempt1[1], Number(attempt1[2])];\n    }\n\n    // Anonymous functions: \"at filename:lineNumber:columnNumber\"\n    var attempt2 = /at ([^ ]+):(\\d+):(?:\\d+)$/.exec(stackLine);\n    if (attempt2) {\n        return [attempt2[1], Number(attempt2[2])];\n    }\n\n    // Firefox style: \"function@filename:lineNumber or @filename:lineNumber\"\n    var attempt3 = /.*@(.+):(\\d+)$/.exec(stackLine);\n    if (attempt3) {\n        return [attempt3[1], Number(attempt3[2])];\n    }\n}\n\nfunction isInternalFrame(stackLine) {\n    var fileNameAndLineNumber = getFileNameAndLineNumber(stackLine);\n\n    if (!fileNameAndLineNumber) {\n        return false;\n    }\n\n    var fileName = fileNameAndLineNumber[0];\n    var lineNumber = fileNameAndLineNumber[1];\n\n    return fileName === qFileName &&\n        lineNumber >= qStartingLine &&\n        lineNumber <= qEndingLine;\n}\n\n// discover own file name and line number range for filtering stack\n// traces\nfunction captureLine() {\n    if (!hasStacks) {\n        return;\n    }\n\n    try {\n        throw new Error();\n    } catch (e) {\n        var lines = e.stack.split(\"\\n\");\n        var firstLine = lines[0].indexOf(\"@\") > 0 ? lines[1] : lines[2];\n        var fileNameAndLineNumber = getFileNameAndLineNumber(firstLine);\n        if (!fileNameAndLineNumber) {\n            return;\n        }\n\n        qFileName = fileNameAndLineNumber[0];\n        return fileNameAndLineNumber[1];\n    }\n}\n\nfunction deprecate(callback, name, alternative) {\n    return function () {\n        if (typeof console !== \"undefined\" &&\n            typeof console.warn === \"function\") {\n            console.warn(name + \" is deprecated, use \" + alternative +\n                         \" instead.\", new Error(\"\").stack);\n        }\n        return callback.apply(callback, arguments);\n    };\n}\n\n// end of shims\n// beginning of real work\n\n/**\n * Constructs a promise for an immediate reference, passes promises through, or\n * coerces promises from different systems.\n * @param value immediate reference or promise\n */\nfunction Q(value) {\n    // If the object is already a Promise, return it directly.  This enables\n    // the resolve function to both be used to created references from objects,\n    // but to tolerably coerce non-promises to promises.\n    if (value instanceof Promise) {\n        return value;\n    }\n\n    // assimilate thenables\n    if (isPromiseAlike(value)) {\n        return coerce(value);\n    } else {\n        return fulfill(value);\n    }\n}\nQ.resolve = Q;\n\n/**\n * Performs a task in a future turn of the event loop.\n * @param {Function} task\n */\nQ.nextTick = nextTick;\n\n/**\n * Controls whether or not long stack traces will be on\n */\nQ.longStackSupport = false;\n\n// enable long stacks if Q_DEBUG is set\nif (typeof process === \"object\" && process && process.env && process.env.Q_DEBUG) {\n    Q.longStackSupport = true;\n}\n\n/**\n * Constructs a {promise, resolve, reject} object.\n *\n * `resolve` is a callback to invoke with a more resolved value for the\n * promise. To fulfill the promise, invoke `resolve` with any value that is\n * not a thenable. To reject the promise, invoke `resolve` with a rejected\n * thenable, or invoke `reject` with the reason directly. To resolve the\n * promise to another thenable, thus putting it in the same state, invoke\n * `resolve` with that other thenable.\n */\nQ.defer = defer;\nfunction defer() {\n    // if \"messages\" is an \"Array\", that indicates that the promise has not yet\n    // been resolved.  If it is \"undefined\", it has been resolved.  Each\n    // element of the messages array is itself an array of complete arguments to\n    // forward to the resolved promise.  We coerce the resolution value to a\n    // promise using the `resolve` function because it handles both fully\n    // non-thenable values and other thenables gracefully.\n    var messages = [], progressListeners = [], resolvedPromise;\n\n    var deferred = object_create(defer.prototype);\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, operands) {\n        var args = array_slice(arguments);\n        if (messages) {\n            messages.push(args);\n            if (op === \"when\" && operands[1]) { // progress operand\n                progressListeners.push(operands[1]);\n            }\n        } else {\n            Q.nextTick(function () {\n                resolvedPromise.promiseDispatch.apply(resolvedPromise, args);\n            });\n        }\n    };\n\n    // XXX deprecated\n    promise.valueOf = function () {\n        if (messages) {\n            return promise;\n        }\n        var nearerValue = nearer(resolvedPromise);\n        if (isPromise(nearerValue)) {\n            resolvedPromise = nearerValue; // shorten chain\n        }\n        return nearerValue;\n    };\n\n    promise.inspect = function () {\n        if (!resolvedPromise) {\n            return { state: \"pending\" };\n        }\n        return resolvedPromise.inspect();\n    };\n\n    if (Q.longStackSupport && hasStacks) {\n        try {\n            throw new Error();\n        } catch (e) {\n            // NOTE: don't try to use `Error.captureStackTrace` or transfer the\n            // accessor around; that causes memory leaks as per GH-111. Just\n            // reify the stack trace as a string ASAP.\n            //\n            // At the same time, cut off the first line; it's always just\n            // \"[object Promise]\\n\", as per the `toString`.\n            promise.stack = e.stack.substring(e.stack.indexOf(\"\\n\") + 1);\n        }\n    }\n\n    // NOTE: we do the checks for `resolvedPromise` in each method, instead of\n    // consolidating them into `become`, since otherwise we'd create new\n    // promises with the lines `become(whatever(value))`. See e.g. GH-252.\n\n    function become(newPromise) {\n        resolvedPromise = newPromise;\n        promise.source = newPromise;\n\n        array_reduce(messages, function (undefined, message) {\n            Q.nextTick(function () {\n                newPromise.promiseDispatch.apply(newPromise, message);\n            });\n        }, void 0);\n\n        messages = void 0;\n        progressListeners = void 0;\n    }\n\n    deferred.promise = promise;\n    deferred.resolve = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(Q(value));\n    };\n\n    deferred.fulfill = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(fulfill(value));\n    };\n    deferred.reject = function (reason) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(reject(reason));\n    };\n    deferred.notify = function (progress) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        array_reduce(progressListeners, function (undefined, progressListener) {\n            Q.nextTick(function () {\n                progressListener(progress);\n            });\n        }, void 0);\n    };\n\n    return deferred;\n}\n\n/**\n * Creates a Node-style callback that will resolve or reject the deferred\n * promise.\n * @returns a nodeback\n */\ndefer.prototype.makeNodeResolver = function () {\n    var self = this;\n    return function (error, value) {\n        if (error) {\n            self.reject(error);\n        } else if (arguments.length > 2) {\n            self.resolve(array_slice(arguments, 1));\n        } else {\n            self.resolve(value);\n        }\n    };\n};\n\n/**\n * @param resolver {Function} a function that returns nothing and accepts\n * the resolve, reject, and notify functions for a deferred.\n * @returns a promise that may be resolved with the given resolve and reject\n * functions, or rejected by a thrown exception in resolver\n */\nQ.Promise = promise; // ES6\nQ.promise = promise;\nfunction promise(resolver) {\n    if (typeof resolver !== \"function\") {\n        throw new TypeError(\"resolver must be a function.\");\n    }\n    var deferred = defer();\n    try {\n        resolver(deferred.resolve, deferred.reject, deferred.notify);\n    } catch (reason) {\n        deferred.reject(reason);\n    }\n    return deferred.promise;\n}\n\npromise.race = race; // ES6\npromise.all = all; // ES6\npromise.reject = reject; // ES6\npromise.resolve = Q; // ES6\n\n// XXX experimental.  This method is a way to denote that a local value is\n// serializable and should be immediately dispatched to a remote upon request,\n// instead of passing a reference.\nQ.passByCopy = function (object) {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return object;\n};\n\nPromise.prototype.passByCopy = function () {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return this;\n};\n\n/**\n * If two promises eventually fulfill to the same value, promises that value,\n * but otherwise rejects.\n * @param x {Any*}\n * @param y {Any*}\n * @returns {Any*} a promise for x and y if they are the same, but a rejection\n * otherwise.\n *\n */\nQ.join = function (x, y) {\n    return Q(x).join(y);\n};\n\nPromise.prototype.join = function (that) {\n    return Q([this, that]).spread(function (x, y) {\n        if (x === y) {\n            // TODO: \"===\" should be Object.is or equiv\n            return x;\n        } else {\n            throw new Error(\"Can't join: not the same: \" + x + \" \" + y);\n        }\n    });\n};\n\n/**\n * Returns a promise for the first of an array of promises to become settled.\n * @param answers {Array[Any*]} promises to race\n * @returns {Any*} the first promise to be settled\n */\nQ.race = race;\nfunction race(answerPs) {\n    return promise(function (resolve, reject) {\n        // Switch to this once we can assume at least ES5\n        // answerPs.forEach(function (answerP) {\n        //     Q(answerP).then(resolve, reject);\n        // });\n        // Use this in the meantime\n        for (var i = 0, len = answerPs.length; i < len; i++) {\n            Q(answerPs[i]).then(resolve, reject);\n        }\n    });\n}\n\nPromise.prototype.race = function () {\n    return this.then(Q.race);\n};\n\n/**\n * Constructs a Promise with a promise descriptor object and optional fallback\n * function.  The descriptor contains methods like when(rejected), get(name),\n * set(name, value), post(name, args), and delete(name), which all\n * return either a value, a promise for a value, or a rejection.  The fallback\n * accepts the operation name, a resolver, and any further arguments that would\n * have been forwarded to the appropriate method above had a method been\n * provided with the proper name.  The API makes no guarantees about the nature\n * of the returned object, apart from that it is usable whereever promises are\n * bought and sold.\n */\nQ.makePromise = Promise;\nfunction Promise(descriptor, fallback, inspect) {\n    if (fallback === void 0) {\n        fallback = function (op) {\n            return reject(new Error(\n                \"Promise does not support operation: \" + op\n            ));\n        };\n    }\n    if (inspect === void 0) {\n        inspect = function () {\n            return {state: \"unknown\"};\n        };\n    }\n\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, args) {\n        var result;\n        try {\n            if (descriptor[op]) {\n                result = descriptor[op].apply(promise, args);\n            } else {\n                result = fallback.call(promise, op, args);\n            }\n        } catch (exception) {\n            result = reject(exception);\n        }\n        if (resolve) {\n            resolve(result);\n        }\n    };\n\n    promise.inspect = inspect;\n\n    // XXX deprecated `valueOf` and `exception` support\n    if (inspect) {\n        var inspected = inspect();\n        if (inspected.state === \"rejected\") {\n            promise.exception = inspected.reason;\n        }\n\n        promise.valueOf = function () {\n            var inspected = inspect();\n            if (inspected.state === \"pending\" ||\n                inspected.state === \"rejected\") {\n                return promise;\n            }\n            return inspected.value;\n        };\n    }\n\n    return promise;\n}\n\nPromise.prototype.toString = function () {\n    return \"[object Promise]\";\n};\n\nPromise.prototype.then = function (fulfilled, rejected, progressed) {\n    var self = this;\n    var deferred = defer();\n    var done = false;   // ensure the untrusted promise makes at most a\n                        // single call to one of the callbacks\n\n    function _fulfilled(value) {\n        try {\n            return typeof fulfilled === \"function\" ? fulfilled(value) : value;\n        } catch (exception) {\n            return reject(exception);\n        }\n    }\n\n    function _rejected(exception) {\n        if (typeof rejected === \"function\") {\n            makeStackTraceLong(exception, self);\n            try {\n                return rejected(exception);\n            } catch (newException) {\n                return reject(newException);\n            }\n        }\n        return reject(exception);\n    }\n\n    function _progressed(value) {\n        return typeof progressed === \"function\" ? progressed(value) : value;\n    }\n\n    Q.nextTick(function () {\n        self.promiseDispatch(function (value) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_fulfilled(value));\n        }, \"when\", [function (exception) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_rejected(exception));\n        }]);\n    });\n\n    // Progress propagator need to be attached in the current tick.\n    self.promiseDispatch(void 0, \"when\", [void 0, function (value) {\n        var newValue;\n        var threw = false;\n        try {\n            newValue = _progressed(value);\n        } catch (e) {\n            threw = true;\n            if (Q.onerror) {\n                Q.onerror(e);\n            } else {\n                throw e;\n            }\n        }\n\n        if (!threw) {\n            deferred.notify(newValue);\n        }\n    }]);\n\n    return deferred.promise;\n};\n\nQ.tap = function (promise, callback) {\n    return Q(promise).tap(callback);\n};\n\n/**\n * Works almost like \"finally\", but not called for rejections.\n * Original resolution value is passed through callback unaffected.\n * Callback may return a promise that will be awaited for.\n * @param {Function} callback\n * @returns {Q.Promise}\n * @example\n * doSomething()\n *   .then(...)\n *   .tap(console.log)\n *   .then(...);\n */\nPromise.prototype.tap = function (callback) {\n    callback = Q(callback);\n\n    return this.then(function (value) {\n        return callback.fcall(value).thenResolve(value);\n    });\n};\n\n/**\n * Registers an observer on a promise.\n *\n * Guarantees:\n *\n * 1. that fulfilled and rejected will be called only once.\n * 2. that either the fulfilled callback or the rejected callback will be\n *    called, but not both.\n * 3. that fulfilled and rejected will not be called in this turn.\n *\n * @param value      promise or immediate reference to observe\n * @param fulfilled  function to be called with the fulfilled value\n * @param rejected   function to be called with the rejection exception\n * @param progressed function to be called on any progress notifications\n * @return promise for the return value from the invoked callback\n */\nQ.when = when;\nfunction when(value, fulfilled, rejected, progressed) {\n    return Q(value).then(fulfilled, rejected, progressed);\n}\n\nPromise.prototype.thenResolve = function (value) {\n    return this.then(function () { return value; });\n};\n\nQ.thenResolve = function (promise, value) {\n    return Q(promise).thenResolve(value);\n};\n\nPromise.prototype.thenReject = function (reason) {\n    return this.then(function () { throw reason; });\n};\n\nQ.thenReject = function (promise, reason) {\n    return Q(promise).thenReject(reason);\n};\n\n/**\n * If an object is not a promise, it is as \"near\" as possible.\n * If a promise is rejected, it is as \"near\" as possible too.\n * If it’s a fulfilled promise, the fulfillment value is nearer.\n * If it’s a deferred promise and the deferred has been resolved, the\n * resolution is \"nearer\".\n * @param object\n * @returns most resolved (nearest) form of the object\n */\n\n// XXX should we re-do this?\nQ.nearer = nearer;\nfunction nearer(value) {\n    if (isPromise(value)) {\n        var inspected = value.inspect();\n        if (inspected.state === \"fulfilled\") {\n            return inspected.value;\n        }\n    }\n    return value;\n}\n\n/**\n * @returns whether the given object is a promise.\n * Otherwise it is a fulfilled value.\n */\nQ.isPromise = isPromise;\nfunction isPromise(object) {\n    return object instanceof Promise;\n}\n\nQ.isPromiseAlike = isPromiseAlike;\nfunction isPromiseAlike(object) {\n    return isObject(object) && typeof object.then === \"function\";\n}\n\n/**\n * @returns whether the given object is a pending promise, meaning not\n * fulfilled or rejected.\n */\nQ.isPending = isPending;\nfunction isPending(object) {\n    return isPromise(object) && object.inspect().state === \"pending\";\n}\n\nPromise.prototype.isPending = function () {\n    return this.inspect().state === \"pending\";\n};\n\n/**\n * @returns whether the given object is a value or fulfilled\n * promise.\n */\nQ.isFulfilled = isFulfilled;\nfunction isFulfilled(object) {\n    return !isPromise(object) || object.inspect().state === \"fulfilled\";\n}\n\nPromise.prototype.isFulfilled = function () {\n    return this.inspect().state === \"fulfilled\";\n};\n\n/**\n * @returns whether the given object is a rejected promise.\n */\nQ.isRejected = isRejected;\nfunction isRejected(object) {\n    return isPromise(object) && object.inspect().state === \"rejected\";\n}\n\nPromise.prototype.isRejected = function () {\n    return this.inspect().state === \"rejected\";\n};\n\n//// BEGIN UNHANDLED REJECTION TRACKING\n\n// This promise library consumes exceptions thrown in handlers so they can be\n// handled by a subsequent promise.  The exceptions get added to this array when\n// they are created, and removed when they are handled.  Note that in ES6 or\n// shimmed environments, this would naturally be a `Set`.\nvar unhandledReasons = [];\nvar unhandledRejections = [];\nvar reportedUnhandledRejections = [];\nvar trackUnhandledRejections = true;\n\nfunction resetUnhandledRejections() {\n    unhandledReasons.length = 0;\n    unhandledRejections.length = 0;\n\n    if (!trackUnhandledRejections) {\n        trackUnhandledRejections = true;\n    }\n}\n\nfunction trackRejection(promise, reason) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n    if (typeof process === \"object\" && typeof process.emit === \"function\") {\n        Q.nextTick.runAfter(function () {\n            if (array_indexOf(unhandledRejections, promise) !== -1) {\n                process.emit(\"unhandledRejection\", reason, promise);\n                reportedUnhandledRejections.push(promise);\n            }\n        });\n    }\n\n    unhandledRejections.push(promise);\n    if (reason && typeof reason.stack !== \"undefined\") {\n        unhandledReasons.push(reason.stack);\n    } else {\n        unhandledReasons.push(\"(no stack) \" + reason);\n    }\n}\n\nfunction untrackRejection(promise) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n\n    var at = array_indexOf(unhandledRejections, promise);\n    if (at !== -1) {\n        if (typeof process === \"object\" && typeof process.emit === \"function\") {\n            Q.nextTick.runAfter(function () {\n                var atReport = array_indexOf(reportedUnhandledRejections, promise);\n                if (atReport !== -1) {\n                    process.emit(\"rejectionHandled\", unhandledReasons[at], promise);\n                    reportedUnhandledRejections.splice(atReport, 1);\n                }\n            });\n        }\n        unhandledRejections.splice(at, 1);\n        unhandledReasons.splice(at, 1);\n    }\n}\n\nQ.resetUnhandledRejections = resetUnhandledRejections;\n\nQ.getUnhandledReasons = function () {\n    // Make a copy so that consumers can't interfere with our internal state.\n    return unhandledReasons.slice();\n};\n\nQ.stopUnhandledRejectionTracking = function () {\n    resetUnhandledRejections();\n    trackUnhandledRejections = false;\n};\n\nresetUnhandledRejections();\n\n//// END UNHANDLED REJECTION TRACKING\n\n/**\n * Constructs a rejected promise.\n * @param reason value describing the failure\n */\nQ.reject = reject;\nfunction reject(reason) {\n    var rejection = Promise({\n        \"when\": function (rejected) {\n            // note that the error has been handled\n            if (rejected) {\n                untrackRejection(this);\n            }\n            return rejected ? rejected(reason) : this;\n        }\n    }, function fallback() {\n        return this;\n    }, function inspect() {\n        return { state: \"rejected\", reason: reason };\n    });\n\n    // Note that the reason has not been handled.\n    trackRejection(rejection, reason);\n\n    return rejection;\n}\n\n/**\n * Constructs a fulfilled promise for an immediate reference.\n * @param value immediate reference\n */\nQ.fulfill = fulfill;\nfunction fulfill(value) {\n    return Promise({\n        \"when\": function () {\n            return value;\n        },\n        \"get\": function (name) {\n            return value[name];\n        },\n        \"set\": function (name, rhs) {\n            value[name] = rhs;\n        },\n        \"delete\": function (name) {\n            delete value[name];\n        },\n        \"post\": function (name, args) {\n            // Mark Miller proposes that post with no name should apply a\n            // promised function.\n            if (name === null || name === void 0) {\n                return value.apply(void 0, args);\n            } else {\n                return value[name].apply(value, args);\n            }\n        },\n        \"apply\": function (thisp, args) {\n            return value.apply(thisp, args);\n        },\n        \"keys\": function () {\n            return object_keys(value);\n        }\n    }, void 0, function inspect() {\n        return { state: \"fulfilled\", value: value };\n    });\n}\n\n/**\n * Converts thenables to Q promises.\n * @param promise thenable promise\n * @returns a Q promise\n */\nfunction coerce(promise) {\n    var deferred = defer();\n    Q.nextTick(function () {\n        try {\n            promise.then(deferred.resolve, deferred.reject, deferred.notify);\n        } catch (exception) {\n            deferred.reject(exception);\n        }\n    });\n    return deferred.promise;\n}\n\n/**\n * Annotates an object such that it will never be\n * transferred away from this process over any promise\n * communication channel.\n * @param object\n * @returns promise a wrapping of that object that\n * additionally responds to the \"isDef\" message\n * without a rejection.\n */\nQ.master = master;\nfunction master(object) {\n    return Promise({\n        \"isDef\": function () {}\n    }, function fallback(op, args) {\n        return dispatch(object, op, args);\n    }, function () {\n        return Q(object).inspect();\n    });\n}\n\n/**\n * Spreads the values of a promised array of arguments into the\n * fulfillment callback.\n * @param fulfilled callback that receives variadic arguments from the\n * promised array\n * @param rejected callback that receives the exception if the promise\n * is rejected.\n * @returns a promise for the return value or thrown exception of\n * either callback.\n */\nQ.spread = spread;\nfunction spread(value, fulfilled, rejected) {\n    return Q(value).spread(fulfilled, rejected);\n}\n\nPromise.prototype.spread = function (fulfilled, rejected) {\n    return this.all().then(function (array) {\n        return fulfilled.apply(void 0, array);\n    }, rejected);\n};\n\n/**\n * The async function is a decorator for generator functions, turning\n * them into asynchronous generators.  Although generators are only part\n * of the newest ECMAScript 6 drafts, this code does not cause syntax\n * errors in older engines.  This code should continue to work and will\n * in fact improve over time as the language improves.\n *\n * ES6 generators are currently part of V8 version 3.19 with the\n * --harmony-generators runtime flag enabled.  SpiderMonkey has had them\n * for longer, but under an older Python-inspired form.  This function\n * works on both kinds of generators.\n *\n * Decorates a generator function such that:\n *  - it may yield promises\n *  - execution will continue when that promise is fulfilled\n *  - the value of the yield expression will be the fulfilled value\n *  - it returns a promise for the return value (when the generator\n *    stops iterating)\n *  - the decorated function returns a promise for the return value\n *    of the generator or the first rejected promise among those\n *    yielded.\n *  - if an error is thrown in the generator, it propagates through\n *    every following yield until it is caught, or until it escapes\n *    the generator function altogether, and is translated into a\n *    rejection for the promise returned by the decorated generator.\n */\nQ.async = async;\nfunction async(makeGenerator) {\n    return function () {\n        // when verb is \"send\", arg is a value\n        // when verb is \"throw\", arg is an exception\n        function continuer(verb, arg) {\n            var result;\n\n            // Until V8 3.19 / Chromium 29 is released, SpiderMonkey is the only\n            // engine that has a deployed base of browsers that support generators.\n            // However, SM's generators use the Python-inspired semantics of\n            // outdated ES6 drafts.  We would like to support ES6, but we'd also\n            // like to make it possible to use generators in deployed browsers, so\n            // we also support Python-style generators.  At some point we can remove\n            // this block.\n\n            if (typeof StopIteration === \"undefined\") {\n                // ES6 Generators\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    return reject(exception);\n                }\n                if (result.done) {\n                    return Q(result.value);\n                } else {\n                    return when(result.value, callback, errback);\n                }\n            } else {\n                // SpiderMonkey Generators\n                // FIXME: Remove this case when SM does ES6 generators.\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    if (isStopIteration(exception)) {\n                        return Q(exception.value);\n                    } else {\n                        return reject(exception);\n                    }\n                }\n                return when(result, callback, errback);\n            }\n        }\n        var generator = makeGenerator.apply(this, arguments);\n        var callback = continuer.bind(continuer, \"next\");\n        var errback = continuer.bind(continuer, \"throw\");\n        return callback();\n    };\n}\n\n/**\n * The spawn function is a small wrapper around async that immediately\n * calls the generator and also ends the promise chain, so that any\n * unhandled errors are thrown instead of forwarded to the error\n * handler. This is useful because it's extremely common to run\n * generators at the top-level to work with libraries.\n */\nQ.spawn = spawn;\nfunction spawn(makeGenerator) {\n    Q.done(Q.async(makeGenerator)());\n}\n\n// FIXME: Remove this interface once ES6 generators are in SpiderMonkey.\n/**\n * Throws a ReturnValue exception to stop an asynchronous generator.\n *\n * This interface is a stop-gap measure to support generator return\n * values in older Firefox/SpiderMonkey.  In browsers that support ES6\n * generators like Chromium 29, just use \"return\" in your generator\n * functions.\n *\n * @param value the return value for the surrounding generator\n * @throws ReturnValue exception with the value.\n * @example\n * // ES6 style\n * Q.async(function* () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      return foo + bar;\n * })\n * // Older SpiderMonkey style\n * Q.async(function () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      Q.return(foo + bar);\n * })\n */\nQ[\"return\"] = _return;\nfunction _return(value) {\n    throw new QReturnValue(value);\n}\n\n/**\n * The promised function decorator ensures that any promise arguments\n * are settled and passed as values (`this` is also settled and passed\n * as a value).  It will also ensure that the result of a function is\n * always a promise.\n *\n * @example\n * var add = Q.promised(function (a, b) {\n *     return a + b;\n * });\n * add(Q(a), Q(B));\n *\n * @param {function} callback The function to decorate\n * @returns {function} a function that has been decorated.\n */\nQ.promised = promised;\nfunction promised(callback) {\n    return function () {\n        return spread([this, all(arguments)], function (self, args) {\n            return callback.apply(self, args);\n        });\n    };\n}\n\n/**\n * sends a message to a value in a future turn\n * @param object* the recipient\n * @param op the name of the message operation, e.g., \"when\",\n * @param args further arguments to be forwarded to the operation\n * @returns result {Promise} a promise for the result of the operation\n */\nQ.dispatch = dispatch;\nfunction dispatch(object, op, args) {\n    return Q(object).dispatch(op, args);\n}\n\nPromise.prototype.dispatch = function (op, args) {\n    var self = this;\n    var deferred = defer();\n    Q.nextTick(function () {\n        self.promiseDispatch(deferred.resolve, op, args);\n    });\n    return deferred.promise;\n};\n\n/**\n * Gets the value of a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to get\n * @return promise for the property value\n */\nQ.get = function (object, key) {\n    return Q(object).dispatch(\"get\", [key]);\n};\n\nPromise.prototype.get = function (key) {\n    return this.dispatch(\"get\", [key]);\n};\n\n/**\n * Sets the value of a property in a future turn.\n * @param object    promise or immediate reference for object object\n * @param name      name of property to set\n * @param value     new value of property\n * @return promise for the return value\n */\nQ.set = function (object, key, value) {\n    return Q(object).dispatch(\"set\", [key, value]);\n};\n\nPromise.prototype.set = function (key, value) {\n    return this.dispatch(\"set\", [key, value]);\n};\n\n/**\n * Deletes a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to delete\n * @return promise for the return value\n */\nQ.del = // XXX legacy\nQ[\"delete\"] = function (object, key) {\n    return Q(object).dispatch(\"delete\", [key]);\n};\n\nPromise.prototype.del = // XXX legacy\nPromise.prototype[\"delete\"] = function (key) {\n    return this.dispatch(\"delete\", [key]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param value     a value to post, typically an array of\n *                  invocation arguments for promises that\n *                  are ultimately backed with `resolve` values,\n *                  as opposed to those backed with URLs\n *                  wherein the posted value can be any\n *                  JSON serializable object.\n * @return promise for the return value\n */\n// bound locally because it is used by other methods\nQ.mapply = // XXX As proposed by \"Redsandro\"\nQ.post = function (object, name, args) {\n    return Q(object).dispatch(\"post\", [name, args]);\n};\n\nPromise.prototype.mapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.post = function (name, args) {\n    return this.dispatch(\"post\", [name, args]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param ...args   array of invocation arguments\n * @return promise for the return value\n */\nQ.send = // XXX Mark Miller's proposed parlance\nQ.mcall = // XXX As proposed by \"Redsandro\"\nQ.invoke = function (object, name /*...args*/) {\n    return Q(object).dispatch(\"post\", [name, array_slice(arguments, 2)]);\n};\n\nPromise.prototype.send = // XXX Mark Miller's proposed parlance\nPromise.prototype.mcall = // XXX As proposed by \"Redsandro\"\nPromise.prototype.invoke = function (name /*...args*/) {\n    return this.dispatch(\"post\", [name, array_slice(arguments, 1)]);\n};\n\n/**\n * Applies the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param args      array of application arguments\n */\nQ.fapply = function (object, args) {\n    return Q(object).dispatch(\"apply\", [void 0, args]);\n};\n\nPromise.prototype.fapply = function (args) {\n    return this.dispatch(\"apply\", [void 0, args]);\n};\n\n/**\n * Calls the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ[\"try\"] =\nQ.fcall = function (object /* ...args*/) {\n    return Q(object).dispatch(\"apply\", [void 0, array_slice(arguments, 1)]);\n};\n\nPromise.prototype.fcall = function (/*...args*/) {\n    return this.dispatch(\"apply\", [void 0, array_slice(arguments)]);\n};\n\n/**\n * Binds the promised function, transforming return values into a fulfilled\n * promise and thrown errors into a rejected one.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ.fbind = function (object /*...args*/) {\n    var promise = Q(object);\n    var args = array_slice(arguments, 1);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\nPromise.prototype.fbind = function (/*...args*/) {\n    var promise = this;\n    var args = array_slice(arguments);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\n\n/**\n * Requests the names of the owned properties of a promised\n * object in a future turn.\n * @param object    promise or immediate reference for target object\n * @return promise for the keys of the eventually settled object\n */\nQ.keys = function (object) {\n    return Q(object).dispatch(\"keys\", []);\n};\n\nPromise.prototype.keys = function () {\n    return this.dispatch(\"keys\", []);\n};\n\n/**\n * Turns an array of promises into a promise for an array.  If any of\n * the promises gets rejected, the whole array is rejected immediately.\n * @param {Array*} an array (or promise for an array) of values (or\n * promises for values)\n * @returns a promise for an array of the corresponding values\n */\n// By Mark Miller\n// http://wiki.ecmascript.org/doku.php?id=strawman:concurrency&rev=1308776521#allfulfilled\nQ.all = all;\nfunction all(promises) {\n    return when(promises, function (promises) {\n        var pendingCount = 0;\n        var deferred = defer();\n        array_reduce(promises, function (undefined, promise, index) {\n            var snapshot;\n            if (\n                isPromise(promise) &&\n                (snapshot = promise.inspect()).state === \"fulfilled\"\n            ) {\n                promises[index] = snapshot.value;\n            } else {\n                ++pendingCount;\n                when(\n                    promise,\n                    function (value) {\n                        promises[index] = value;\n                        if (--pendingCount === 0) {\n                            deferred.resolve(promises);\n                        }\n                    },\n                    deferred.reject,\n                    function (progress) {\n                        deferred.notify({ index: index, value: progress });\n                    }\n                );\n            }\n        }, void 0);\n        if (pendingCount === 0) {\n            deferred.resolve(promises);\n        }\n        return deferred.promise;\n    });\n}\n\nPromise.prototype.all = function () {\n    return all(this);\n};\n\n/**\n * Returns the first resolved promise of an array. Prior rejected promises are\n * ignored.  Rejects only if all promises are rejected.\n * @param {Array*} an array containing values or promises for values\n * @returns a promise fulfilled with the value of the first resolved promise,\n * or a rejected promise if all promises are rejected.\n */\nQ.any = any;\n\nfunction any(promises) {\n    if (promises.length === 0) {\n        return Q.resolve();\n    }\n\n    var deferred = Q.defer();\n    var pendingCount = 0;\n    array_reduce(promises, function (prev, current, index) {\n        var promise = promises[index];\n\n        pendingCount++;\n\n        when(promise, onFulfilled, onRejected, onProgress);\n        function onFulfilled(result) {\n            deferred.resolve(result);\n        }\n        function onRejected() {\n            pendingCount--;\n            if (pendingCount === 0) {\n                deferred.reject(new Error(\n                    \"Can't get fulfillment value from any promise, all \" +\n                    \"promises were rejected.\"\n                ));\n            }\n        }\n        function onProgress(progress) {\n            deferred.notify({\n                index: index,\n                value: progress\n            });\n        }\n    }, undefined);\n\n    return deferred.promise;\n}\n\nPromise.prototype.any = function () {\n    return any(this);\n};\n\n/**\n * Waits for all promises to be settled, either fulfilled or\n * rejected.  This is distinct from `all` since that would stop\n * waiting at the first rejection.  The promise returned by\n * `allResolved` will never be rejected.\n * @param promises a promise for an array (or an array) of promises\n * (or values)\n * @return a promise for an array of promises\n */\nQ.allResolved = deprecate(allResolved, \"allResolved\", \"allSettled\");\nfunction allResolved(promises) {\n    return when(promises, function (promises) {\n        promises = array_map(promises, Q);\n        return when(all(array_map(promises, function (promise) {\n            return when(promise, noop, noop);\n        })), function () {\n            return promises;\n        });\n    });\n}\n\nPromise.prototype.allResolved = function () {\n    return allResolved(this);\n};\n\n/**\n * @see Promise#allSettled\n */\nQ.allSettled = allSettled;\nfunction allSettled(promises) {\n    return Q(promises).allSettled();\n}\n\n/**\n * Turns an array of promises into a promise for an array of their states (as\n * returned by `inspect`) when they have all settled.\n * @param {Array[Any*]} values an array (or promise for an array) of values (or\n * promises for values)\n * @returns {Array[State]} an array of states for the respective values.\n */\nPromise.prototype.allSettled = function () {\n    return this.then(function (promises) {\n        return all(array_map(promises, function (promise) {\n            promise = Q(promise);\n            function regardless() {\n                return promise.inspect();\n            }\n            return promise.then(regardless, regardless);\n        }));\n    });\n};\n\n/**\n * Captures the failure of a promise, giving an oportunity to recover\n * with a callback.  If the given promise is fulfilled, the returned\n * promise is fulfilled.\n * @param {Any*} promise for something\n * @param {Function} callback to fulfill the returned promise if the\n * given promise is rejected\n * @returns a promise for the return value of the callback\n */\nQ.fail = // XXX legacy\nQ[\"catch\"] = function (object, rejected) {\n    return Q(object).then(void 0, rejected);\n};\n\nPromise.prototype.fail = // XXX legacy\nPromise.prototype[\"catch\"] = function (rejected) {\n    return this.then(void 0, rejected);\n};\n\n/**\n * Attaches a listener that can respond to progress notifications from a\n * promise's originating deferred. This listener receives the exact arguments\n * passed to ``deferred.notify``.\n * @param {Any*} promise for something\n * @param {Function} callback to receive any progress notifications\n * @returns the given promise, unchanged\n */\nQ.progress = progress;\nfunction progress(object, progressed) {\n    return Q(object).then(void 0, void 0, progressed);\n}\n\nPromise.prototype.progress = function (progressed) {\n    return this.then(void 0, void 0, progressed);\n};\n\n/**\n * Provides an opportunity to observe the settling of a promise,\n * regardless of whether the promise is fulfilled or rejected.  Forwards\n * the resolution to the returned promise when the callback is done.\n * The callback can return a promise to defer completion.\n * @param {Any*} promise\n * @param {Function} callback to observe the resolution of the given\n * promise, takes no arguments.\n * @returns a promise for the resolution of the given promise when\n * ``fin`` is done.\n */\nQ.fin = // XXX legacy\nQ[\"finally\"] = function (object, callback) {\n    return Q(object)[\"finally\"](callback);\n};\n\nPromise.prototype.fin = // XXX legacy\nPromise.prototype[\"finally\"] = function (callback) {\n    callback = Q(callback);\n    return this.then(function (value) {\n        return callback.fcall().then(function () {\n            return value;\n        });\n    }, function (reason) {\n        // TODO attempt to recycle the rejection with \"this\".\n        return callback.fcall().then(function () {\n            throw reason;\n        });\n    });\n};\n\n/**\n * Terminates a chain of promises, forcing rejections to be\n * thrown as exceptions.\n * @param {Any*} promise at the end of a chain of promises\n * @returns nothing\n */\nQ.done = function (object, fulfilled, rejected, progress) {\n    return Q(object).done(fulfilled, rejected, progress);\n};\n\nPromise.prototype.done = function (fulfilled, rejected, progress) {\n    var onUnhandledError = function (error) {\n        // forward to a future turn so that ``when``\n        // does not catch it and turn it into a rejection.\n        Q.nextTick(function () {\n            makeStackTraceLong(error, promise);\n            if (Q.onerror) {\n                Q.onerror(error);\n            } else {\n                throw error;\n            }\n        });\n    };\n\n    // Avoid unnecessary `nextTick`ing via an unnecessary `when`.\n    var promise = fulfilled || rejected || progress ?\n        this.then(fulfilled, rejected, progress) :\n        this;\n\n    if (typeof process === \"object\" && process && process.domain) {\n        onUnhandledError = process.domain.bind(onUnhandledError);\n    }\n\n    promise.then(void 0, onUnhandledError);\n};\n\n/**\n * Causes a promise to be rejected if it does not get fulfilled before\n * some milliseconds time out.\n * @param {Any*} promise\n * @param {Number} milliseconds timeout\n * @param {Any*} custom error message or Error object (optional)\n * @returns a promise for the resolution of the given promise if it is\n * fulfilled before the timeout, otherwise rejected.\n */\nQ.timeout = function (object, ms, error) {\n    return Q(object).timeout(ms, error);\n};\n\nPromise.prototype.timeout = function (ms, error) {\n    var deferred = defer();\n    var timeoutId = setTimeout(function () {\n        if (!error || \"string\" === typeof error) {\n            error = new Error(error || \"Timed out after \" + ms + \" ms\");\n            error.code = \"ETIMEDOUT\";\n        }\n        deferred.reject(error);\n    }, ms);\n\n    this.then(function (value) {\n        clearTimeout(timeoutId);\n        deferred.resolve(value);\n    }, function (exception) {\n        clearTimeout(timeoutId);\n        deferred.reject(exception);\n    }, deferred.notify);\n\n    return deferred.promise;\n};\n\n/**\n * Returns a promise for the given value (or promised value), some\n * milliseconds after it resolved. Passes rejections immediately.\n * @param {Any*} promise\n * @param {Number} milliseconds\n * @returns a promise for the resolution of the given promise after milliseconds\n * time has elapsed since the resolution of the given promise.\n * If the given promise rejects, that is passed immediately.\n */\nQ.delay = function (object, timeout) {\n    if (timeout === void 0) {\n        timeout = object;\n        object = void 0;\n    }\n    return Q(object).delay(timeout);\n};\n\nPromise.prototype.delay = function (timeout) {\n    return this.then(function (value) {\n        var deferred = defer();\n        setTimeout(function () {\n            deferred.resolve(value);\n        }, timeout);\n        return deferred.promise;\n    });\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided as an array, and returns a promise.\n *\n *      Q.nfapply(FS.readFile, [__filename])\n *      .then(function (content) {\n *      })\n *\n */\nQ.nfapply = function (callback, args) {\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfapply = function (args) {\n    var deferred = defer();\n    var nodeArgs = array_slice(args);\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided individually, and returns a promise.\n * @example\n * Q.nfcall(FS.readFile, __filename)\n * .then(function (content) {\n * })\n *\n */\nQ.nfcall = function (callback /*...args*/) {\n    var args = array_slice(arguments, 1);\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfcall = function (/*...args*/) {\n    var nodeArgs = array_slice(arguments);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Wraps a NodeJS continuation passing function and returns an equivalent\n * version that returns a promise.\n * @example\n * Q.nfbind(FS.readFile, __filename)(\"utf-8\")\n * .then(console.log)\n * .done()\n */\nQ.nfbind =\nQ.denodeify = function (callback /*...args*/) {\n    var baseArgs = array_slice(arguments, 1);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        Q(callback).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nfbind =\nPromise.prototype.denodeify = function (/*...args*/) {\n    var args = array_slice(arguments);\n    args.unshift(this);\n    return Q.denodeify.apply(void 0, args);\n};\n\nQ.nbind = function (callback, thisp /*...args*/) {\n    var baseArgs = array_slice(arguments, 2);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        function bound() {\n            return callback.apply(thisp, arguments);\n        }\n        Q(bound).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nbind = function (/*thisp, ...args*/) {\n    var args = array_slice(arguments, 0);\n    args.unshift(this);\n    return Q.nbind.apply(void 0, args);\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback with a given array of arguments, plus a provided callback.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param {Array} args arguments to pass to the method; the callback\n * will be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nmapply = // XXX As proposed by \"Redsandro\"\nQ.npost = function (object, name, args) {\n    return Q(object).npost(name, args);\n};\n\nPromise.prototype.nmapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.npost = function (name, args) {\n    var nodeArgs = array_slice(args || []);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback, forwarding the given variadic arguments, plus a provided\n * callback argument.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param ...args arguments to pass to the method; the callback will\n * be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nsend = // XXX Based on Mark Miller's proposed \"send\"\nQ.nmcall = // XXX Based on \"Redsandro's\" proposal\nQ.ninvoke = function (object, name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 2);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    Q(object).dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\nPromise.prototype.nsend = // XXX Based on Mark Miller's proposed \"send\"\nPromise.prototype.nmcall = // XXX Based on \"Redsandro's\" proposal\nPromise.prototype.ninvoke = function (name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 1);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * If a function would like to support both Node continuation-passing-style and\n * promise-returning-style, it can end its internal promise chain with\n * `nodeify(nodeback)`, forwarding the optional nodeback argument.  If the user\n * elects to use a nodeback, the result will be sent there.  If they do not\n * pass a nodeback, they will receive the result promise.\n * @param object a result (or a promise for a result)\n * @param {Function} nodeback a Node.js-style callback\n * @returns either the promise or nothing\n */\nQ.nodeify = nodeify;\nfunction nodeify(object, nodeback) {\n    return Q(object).nodeify(nodeback);\n}\n\nPromise.prototype.nodeify = function (nodeback) {\n    if (nodeback) {\n        this.then(function (value) {\n            Q.nextTick(function () {\n                nodeback(null, value);\n            });\n        }, function (error) {\n            Q.nextTick(function () {\n                nodeback(error);\n            });\n        });\n    } else {\n        return this;\n    }\n};\n\nQ.noConflict = function() {\n    throw new Error(\"Q.noConflict only works when Q is used as a global\");\n};\n\n// All code before this point will be filtered from stack traces.\nvar qEndingLine = captureLine();\n\nreturn Q;\n\n});\n"]} 23242 },{"_process":13}],162:[function(require,module,exports){ 23243 /** 23244 * Module dependencies. 23245 */ 23246 23247 var Emitter = require('emitter'); 23248 var reduce = require('reduce'); 23249 23250 /** 23251 * Root reference for iframes. 23252 */ 23253 23254 var root; 23255 if (typeof window !== 'undefined') { // Browser window 23256 root = window; 23257 } else if (typeof self !== 'undefined') { // Web Worker 23258 root = self; 23259 } else { // Other environments 23260 root = this; 23261 } 23262 23263 /** 23264 * Noop. 23265 */ 23266 23267 function noop(){}; 23268 23269 /** 23270 * Check if `obj` is a host object, 23271 * we don't want to serialize these :) 23272 * 23273 * TODO: future proof, move to compoent land 23274 * 23275 * @param {Object} obj 23276 * @return {Boolean} 23277 * @api private 23278 */ 23279 23280 function isHost(obj) { 23281 var str = {}.toString.call(obj); 23282 23283 switch (str) { 23284 case '[object File]': 23285 case '[object Blob]': 23286 case '[object FormData]': 23287 return true; 23288 default: 23289 return false; 23290 } 23291 } 23292 23293 /** 23294 * Determine XHR. 23295 */ 23296 23297 request.getXHR = function () { 23298 if (root.XMLHttpRequest 23299 && (!root.location || 'file:' != root.location.protocol 23300 || !root.ActiveXObject)) { 23301 return new XMLHttpRequest; 23302 } else { 23303 try { return new ActiveXObject('Microsoft.XMLHTTP'); } catch(e) {} 23304 try { return new ActiveXObject('Msxml2.XMLHTTP.6.0'); } catch(e) {} 23305 try { return new ActiveXObject('Msxml2.XMLHTTP.3.0'); } catch(e) {} 23306 try { return new ActiveXObject('Msxml2.XMLHTTP'); } catch(e) {} 23307 } 23308 return false; 23309 }; 23310 23311 /** 23312 * Removes leading and trailing whitespace, added to support IE. 23313 * 23314 * @param {String} s 23315 * @return {String} 23316 * @api private 23317 */ 23318 23319 var trim = ''.trim 23320 ? function(s) { return s.trim(); } 23321 : function(s) { return s.replace(/(^\s*|\s*$)/g, ''); }; 23322 23323 /** 23324 * Check if `obj` is an object. 23325 * 23326 * @param {Object} obj 23327 * @return {Boolean} 23328 * @api private 23329 */ 23330 23331 function isObject(obj) { 23332 return obj === Object(obj); 23333 } 23334 23335 /** 23336 * Serialize the given `obj`. 23337 * 23338 * @param {Object} obj 23339 * @return {String} 23340 * @api private 23341 */ 23342 23343 function serialize(obj) { 23344 if (!isObject(obj)) return obj; 23345 var pairs = []; 23346 for (var key in obj) { 23347 if (null != obj[key]) { 23348 pushEncodedKeyValuePair(pairs, key, obj[key]); 23349 } 23350 } 23351 return pairs.join('&'); 23352 } 23353 23354 /** 23355 * Helps 'serialize' with serializing arrays. 23356 * Mutates the pairs array. 23357 * 23358 * @param {Array} pairs 23359 * @param {String} key 23360 * @param {Mixed} val 23361 */ 23362 23363 function pushEncodedKeyValuePair(pairs, key, val) { 23364 if (Array.isArray(val)) { 23365 return val.forEach(function(v) { 23366 pushEncodedKeyValuePair(pairs, key, v); 23367 }); 23368 } 23369 pairs.push(encodeURIComponent(key) 23370 + '=' + encodeURIComponent(val)); 23371 } 23372 23373 /** 23374 * Expose serialization method. 23375 */ 23376 23377 request.serializeObject = serialize; 23378 23379 /** 23380 * Parse the given x-www-form-urlencoded `str`. 23381 * 23382 * @param {String} str 23383 * @return {Object} 23384 * @api private 23385 */ 23386 23387 function parseString(str) { 23388 var obj = {}; 23389 var pairs = str.split('&'); 23390 var parts; 23391 var pair; 23392 23393 for (var i = 0, len = pairs.length; i < len; ++i) { 23394 pair = pairs[i]; 23395 parts = pair.split('='); 23396 obj[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]); 23397 } 23398 23399 return obj; 23400 } 23401 23402 /** 23403 * Expose parser. 23404 */ 23405 23406 request.parseString = parseString; 23407 23408 /** 23409 * Default MIME type map. 23410 * 23411 * superagent.types.xml = 'application/xml'; 23412 * 23413 */ 23414 23415 request.types = { 23416 html: 'text/html', 23417 json: 'application/json', 23418 xml: 'application/xml', 23419 urlencoded: 'application/x-www-form-urlencoded', 23420 'form': 'application/x-www-form-urlencoded', 23421 'form-data': 'application/x-www-form-urlencoded' 23422 }; 23423 23424 /** 23425 * Default serialization map. 23426 * 23427 * superagent.serialize['application/xml'] = function(obj){ 23428 * return 'generated xml here'; 23429 * }; 23430 * 23431 */ 23432 23433 request.serialize = { 23434 'application/x-www-form-urlencoded': serialize, 23435 'application/json': JSON.stringify 23436 }; 23437 23438 /** 23439 * Default parsers. 23440 * 23441 * superagent.parse['application/xml'] = function(str){ 23442 * return { object parsed from str }; 23443 * }; 23444 * 23445 */ 23446 23447 request.parse = { 23448 'application/x-www-form-urlencoded': parseString, 23449 'application/json': JSON.parse 23450 }; 23451 23452 /** 23453 * Parse the given header `str` into 23454 * an object containing the mapped fields. 23455 * 23456 * @param {String} str 23457 * @return {Object} 23458 * @api private 23459 */ 23460 23461 function parseHeader(str) { 23462 var lines = str.split(/\r?\n/); 23463 var fields = {}; 23464 var index; 23465 var line; 23466 var field; 23467 var val; 23468 23469 lines.pop(); // trailing CRLF 23470 23471 for (var i = 0, len = lines.length; i < len; ++i) { 23472 line = lines[i]; 23473 index = line.indexOf(':'); 23474 field = line.slice(0, index).toLowerCase(); 23475 val = trim(line.slice(index + 1)); 23476 fields[field] = val; 23477 } 23478 23479 return fields; 23480 } 23481 23482 /** 23483 * Return the mime type for the given `str`. 23484 * 23485 * @param {String} str 23486 * @return {String} 23487 * @api private 23488 */ 23489 23490 function type(str){ 23491 return str.split(/ *; */).shift(); 23492 }; 23493 23494 /** 23495 * Return header field parameters. 23496 * 23497 * @param {String} str 23498 * @return {Object} 23499 * @api private 23500 */ 23501 23502 function params(str){ 23503 return reduce(str.split(/ *; */), function(obj, str){ 23504 var parts = str.split(/ *= */) 23505 , key = parts.shift() 23506 , val = parts.shift(); 23507 23508 if (key && val) obj[key] = val; 23509 return obj; 23510 }, {}); 23511 }; 23512 23513 /** 23514 * Initialize a new `Response` with the given `xhr`. 23515 * 23516 * - set flags (.ok, .error, etc) 23517 * - parse header 23518 * 23519 * Examples: 23520 * 23521 * Aliasing `superagent` as `request` is nice: 23522 * 23523 * request = superagent; 23524 * 23525 * We can use the promise-like API, or pass callbacks: 23526 * 23527 * request.get('/').end(function(res){}); 23528 * request.get('/', function(res){}); 23529 * 23530 * Sending data can be chained: 23531 * 23532 * request 23533 * .post('/user') 23534 * .send({ name: 'tj' }) 23535 * .end(function(res){}); 23536 * 23537 * Or passed to `.send()`: 23538 * 23539 * request 23540 * .post('/user') 23541 * .send({ name: 'tj' }, function(res){}); 23542 * 23543 * Or passed to `.post()`: 23544 * 23545 * request 23546 * .post('/user', { name: 'tj' }) 23547 * .end(function(res){}); 23548 * 23549 * Or further reduced to a single call for simple cases: 23550 * 23551 * request 23552 * .post('/user', { name: 'tj' }, function(res){}); 23553 * 23554 * @param {XMLHTTPRequest} xhr 23555 * @param {Object} options 23556 * @api private 23557 */ 23558 23559 function Response(req, options) { 23560 options = options || {}; 23561 this.req = req; 23562 this.xhr = this.req.xhr; 23563 // responseText is accessible only if responseType is '' or 'text' and on older browsers 23564 this.text = ((this.req.method !='HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text')) || typeof this.xhr.responseType === 'undefined') 23565 ? this.xhr.responseText 23566 : null; 23567 this.statusText = this.req.xhr.statusText; 23568 this.setStatusProperties(this.xhr.status); 23569 this.header = this.headers = parseHeader(this.xhr.getAllResponseHeaders()); 23570 // getAllResponseHeaders sometimes falsely returns "" for CORS requests, but 23571 // getResponseHeader still works. so we get content-type even if getting 23572 // other headers fails. 23573 this.header['content-type'] = this.xhr.getResponseHeader('content-type'); 23574 this.setHeaderProperties(this.header); 23575 this.body = this.req.method != 'HEAD' 23576 ? this.parseBody(this.text ? this.text : this.xhr.response) 23577 : null; 23578 } 23579 23580 /** 23581 * Get case-insensitive `field` value. 23582 * 23583 * @param {String} field 23584 * @return {String} 23585 * @api public 23586 */ 23587 23588 Response.prototype.get = function(field){ 23589 return this.header[field.toLowerCase()]; 23590 }; 23591 23592 /** 23593 * Set header related properties: 23594 * 23595 * - `.type` the content type without params 23596 * 23597 * A response of "Content-Type: text/plain; charset=utf-8" 23598 * will provide you with a `.type` of "text/plain". 23599 * 23600 * @param {Object} header 23601 * @api private 23602 */ 23603 23604 Response.prototype.setHeaderProperties = function(header){ 23605 // content-type 23606 var ct = this.header['content-type'] || ''; 23607 this.type = type(ct); 23608 23609 // params 23610 var obj = params(ct); 23611 for (var key in obj) this[key] = obj[key]; 23612 }; 23613 23614 /** 23615 * Parse the given body `str`. 23616 * 23617 * Used for auto-parsing of bodies. Parsers 23618 * are defined on the `superagent.parse` object. 23619 * 23620 * @param {String} str 23621 * @return {Mixed} 23622 * @api private 23623 */ 23624 23625 Response.prototype.parseBody = function(str){ 23626 var parse = request.parse[this.type]; 23627 return parse && str && (str.length || str instanceof Object) 23628 ? parse(str) 23629 : null; 23630 }; 23631 23632 /** 23633 * Set flags such as `.ok` based on `status`. 23634 * 23635 * For example a 2xx response will give you a `.ok` of __true__ 23636 * whereas 5xx will be __false__ and `.error` will be __true__. The 23637 * `.clientError` and `.serverError` are also available to be more 23638 * specific, and `.statusType` is the class of error ranging from 1..5 23639 * sometimes useful for mapping respond colors etc. 23640 * 23641 * "sugar" properties are also defined for common cases. Currently providing: 23642 * 23643 * - .noContent 23644 * - .badRequest 23645 * - .unauthorized 23646 * - .notAcceptable 23647 * - .notFound 23648 * 23649 * @param {Number} status 23650 * @api private 23651 */ 23652 23653 Response.prototype.setStatusProperties = function(status){ 23654 // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request 23655 if (status === 1223) { 23656 status = 204; 23657 } 23658 23659 var type = status / 100 | 0; 23660 23661 // status / class 23662 this.status = this.statusCode = status; 23663 this.statusType = type; 23664 23665 // basics 23666 this.info = 1 == type; 23667 this.ok = 2 == type; 23668 this.clientError = 4 == type; 23669 this.serverError = 5 == type; 23670 this.error = (4 == type || 5 == type) 23671 ? this.toError() 23672 : false; 23673 23674 // sugar 23675 this.accepted = 202 == status; 23676 this.noContent = 204 == status; 23677 this.badRequest = 400 == status; 23678 this.unauthorized = 401 == status; 23679 this.notAcceptable = 406 == status; 23680 this.notFound = 404 == status; 23681 this.forbidden = 403 == status; 23682 }; 23683 23684 /** 23685 * Return an `Error` representative of this response. 23686 * 23687 * @return {Error} 23688 * @api public 23689 */ 23690 23691 Response.prototype.toError = function(){ 23692 var req = this.req; 23693 var method = req.method; 23694 var url = req.url; 23695 23696 var msg = 'cannot ' + method + ' ' + url + ' (' + this.status + ')'; 23697 var err = new Error(msg); 23698 err.status = this.status; 23699 err.method = method; 23700 err.url = url; 23701 23702 return err; 23703 }; 23704 23705 /** 23706 * Expose `Response`. 23707 */ 23708 23709 request.Response = Response; 23710 23711 /** 23712 * Initialize a new `Request` with the given `method` and `url`. 23713 * 23714 * @param {String} method 23715 * @param {String} url 23716 * @api public 23717 */ 23718 23719 function Request(method, url) { 23720 var self = this; 23721 Emitter.call(this); 23722 this._query = this._query || []; 23723 this.method = method; 23724 this.url = url; 23725 this.header = {}; 23726 this._header = {}; 23727 this.on('end', function(){ 23728 var err = null; 23729 var res = null; 23730 23731 try { 23732 res = new Response(self); 23733 } catch(e) { 23734 err = new Error('Parser is unable to parse the response'); 23735 err.parse = true; 23736 err.original = e; 23737 return self.callback(err); 23738 } 23739 23740 self.emit('response', res); 23741 23742 if (err) { 23743 return self.callback(err, res); 23744 } 23745 23746 if (res.status >= 200 && res.status < 300) { 23747 return self.callback(err, res); 23748 } 23749 23750 var new_err = new Error(res.statusText || 'Unsuccessful HTTP response'); 23751 new_err.original = err; 23752 new_err.response = res; 23753 new_err.status = res.status; 23754 23755 self.callback(new_err, res); 23756 }); 23757 } 23758 23759 /** 23760 * Mixin `Emitter`. 23761 */ 23762 23763 Emitter(Request.prototype); 23764 23765 /** 23766 * Allow for extension 23767 */ 23768 23769 Request.prototype.use = function(fn) { 23770 fn(this); 23771 return this; 23772 } 23773 23774 /** 23775 * Set timeout to `ms`. 23776 * 23777 * @param {Number} ms 23778 * @return {Request} for chaining 23779 * @api public 23780 */ 23781 23782 Request.prototype.timeout = function(ms){ 23783 this._timeout = ms; 23784 return this; 23785 }; 23786 23787 /** 23788 * Clear previous timeout. 23789 * 23790 * @return {Request} for chaining 23791 * @api public 23792 */ 23793 23794 Request.prototype.clearTimeout = function(){ 23795 this._timeout = 0; 23796 clearTimeout(this._timer); 23797 return this; 23798 }; 23799 23800 /** 23801 * Abort the request, and clear potential timeout. 23802 * 23803 * @return {Request} 23804 * @api public 23805 */ 23806 23807 Request.prototype.abort = function(){ 23808 if (this.aborted) return; 23809 this.aborted = true; 23810 this.xhr.abort(); 23811 this.clearTimeout(); 23812 this.emit('abort'); 23813 return this; 23814 }; 23815 23816 /** 23817 * Set header `field` to `val`, or multiple fields with one object. 23818 * 23819 * Examples: 23820 * 23821 * req.get('/') 23822 * .set('Accept', 'application/json') 23823 * .set('X-API-Key', 'foobar') 23824 * .end(callback); 23825 * 23826 * req.get('/') 23827 * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' }) 23828 * .end(callback); 23829 * 23830 * @param {String|Object} field 23831 * @param {String} val 23832 * @return {Request} for chaining 23833 * @api public 23834 */ 23835 23836 Request.prototype.set = function(field, val){ 23837 if (isObject(field)) { 23838 for (var key in field) { 23839 this.set(key, field[key]); 23840 } 23841 return this; 23842 } 23843 this._header[field.toLowerCase()] = val; 23844 this.header[field] = val; 23845 return this; 23846 }; 23847 23848 /** 23849 * Remove header `field`. 23850 * 23851 * Example: 23852 * 23853 * req.get('/') 23854 * .unset('User-Agent') 23855 * .end(callback); 23856 * 23857 * @param {String} field 23858 * @return {Request} for chaining 23859 * @api public 23860 */ 23861 23862 Request.prototype.unset = function(field){ 23863 delete this._header[field.toLowerCase()]; 23864 delete this.header[field]; 23865 return this; 23866 }; 23867 23868 /** 23869 * Get case-insensitive header `field` value. 23870 * 23871 * @param {String} field 23872 * @return {String} 23873 * @api private 23874 */ 23875 23876 Request.prototype.getHeader = function(field){ 23877 return this._header[field.toLowerCase()]; 23878 }; 23879 23880 /** 23881 * Set Content-Type to `type`, mapping values from `request.types`. 23882 * 23883 * Examples: 23884 * 23885 * superagent.types.xml = 'application/xml'; 23886 * 23887 * request.post('/') 23888 * .type('xml') 23889 * .send(xmlstring) 23890 * .end(callback); 23891 * 23892 * request.post('/') 23893 * .type('application/xml') 23894 * .send(xmlstring) 23895 * .end(callback); 23896 * 23897 * @param {String} type 23898 * @return {Request} for chaining 23899 * @api public 23900 */ 23901 23902 Request.prototype.type = function(type){ 23903 this.set('Content-Type', request.types[type] || type); 23904 return this; 23905 }; 23906 23907 /** 23908 * Force given parser 23909 * 23910 * Sets the body parser no matter type. 23911 * 23912 * @param {Function} 23913 * @api public 23914 */ 23915 23916 Request.prototype.parse = function(fn){ 23917 this._parser = fn; 23918 return this; 23919 }; 23920 23921 /** 23922 * Set Accept to `type`, mapping values from `request.types`. 23923 * 23924 * Examples: 23925 * 23926 * superagent.types.json = 'application/json'; 23927 * 23928 * request.get('/agent') 23929 * .accept('json') 23930 * .end(callback); 23931 * 23932 * request.get('/agent') 23933 * .accept('application/json') 23934 * .end(callback); 23935 * 23936 * @param {String} accept 23937 * @return {Request} for chaining 23938 * @api public 23939 */ 23940 23941 Request.prototype.accept = function(type){ 23942 this.set('Accept', request.types[type] || type); 23943 return this; 23944 }; 23945 23946 /** 23947 * Set Authorization field value with `user` and `pass`. 23948 * 23949 * @param {String} user 23950 * @param {String} pass 23951 * @return {Request} for chaining 23952 * @api public 23953 */ 23954 23955 Request.prototype.auth = function(user, pass){ 23956 var str = btoa(user + ':' + pass); 23957 this.set('Authorization', 'Basic ' + str); 23958 return this; 23959 }; 23960 23961 /** 23962 * Add query-string `val`. 23963 * 23964 * Examples: 23965 * 23966 * request.get('/shoes') 23967 * .query('size=10') 23968 * .query({ color: 'blue' }) 23969 * 23970 * @param {Object|String} val 23971 * @return {Request} for chaining 23972 * @api public 23973 */ 23974 23975 Request.prototype.query = function(val){ 23976 if ('string' != typeof val) val = serialize(val); 23977 if (val) this._query.push(val); 23978 return this; 23979 }; 23980 23981 /** 23982 * Write the field `name` and `val` for "multipart/form-data" 23983 * request bodies. 23984 * 23985 * ``` js 23986 * request.post('/upload') 23987 * .field('foo', 'bar') 23988 * .end(callback); 23989 * ``` 23990 * 23991 * @param {String} name 23992 * @param {String|Blob|File} val 23993 * @return {Request} for chaining 23994 * @api public 23995 */ 23996 23997 Request.prototype.field = function(name, val){ 23998 if (!this._formData) this._formData = new root.FormData(); 23999 this._formData.append(name, val); 24000 return this; 24001 }; 24002 24003 /** 24004 * Queue the given `file` as an attachment to the specified `field`, 24005 * with optional `filename`. 24006 * 24007 * ``` js 24008 * request.post('/upload') 24009 * .attach(new Blob(['<a id="a"><b id="b">hey!</b></a>'], { type: "text/html"})) 24010 * .end(callback); 24011 * ``` 24012 * 24013 * @param {String} field 24014 * @param {Blob|File} file 24015 * @param {String} filename 24016 * @return {Request} for chaining 24017 * @api public 24018 */ 24019 24020 Request.prototype.attach = function(field, file, filename){ 24021 if (!this._formData) this._formData = new root.FormData(); 24022 this._formData.append(field, file, filename); 24023 return this; 24024 }; 24025 24026 /** 24027 * Send `data`, defaulting the `.type()` to "json" when 24028 * an object is given. 24029 * 24030 * Examples: 24031 * 24032 * // querystring 24033 * request.get('/search') 24034 * .end(callback) 24035 * 24036 * // multiple data "writes" 24037 * request.get('/search') 24038 * .send({ search: 'query' }) 24039 * .send({ range: '1..5' }) 24040 * .send({ order: 'desc' }) 24041 * .end(callback) 24042 * 24043 * // manual json 24044 * request.post('/user') 24045 * .type('json') 24046 * .send('{"name":"tj"}') 24047 * .end(callback) 24048 * 24049 * // auto json 24050 * request.post('/user') 24051 * .send({ name: 'tj' }) 24052 * .end(callback) 24053 * 24054 * // manual x-www-form-urlencoded 24055 * request.post('/user') 24056 * .type('form') 24057 * .send('name=tj') 24058 * .end(callback) 24059 * 24060 * // auto x-www-form-urlencoded 24061 * request.post('/user') 24062 * .type('form') 24063 * .send({ name: 'tj' }) 24064 * .end(callback) 24065 * 24066 * // defaults to x-www-form-urlencoded 24067 * request.post('/user') 24068 * .send('name=tobi') 24069 * .send('species=ferret') 24070 * .end(callback) 24071 * 24072 * @param {String|Object} data 24073 * @return {Request} for chaining 24074 * @api public 24075 */ 24076 24077 Request.prototype.send = function(data){ 24078 var obj = isObject(data); 24079 var type = this.getHeader('Content-Type'); 24080 24081 // merge 24082 if (obj && isObject(this._data)) { 24083 for (var key in data) { 24084 this._data[key] = data[key]; 24085 } 24086 } else if ('string' == typeof data) { 24087 if (!type) this.type('form'); 24088 type = this.getHeader('Content-Type'); 24089 if ('application/x-www-form-urlencoded' == type) { 24090 this._data = this._data 24091 ? this._data + '&' + data 24092 : data; 24093 } else { 24094 this._data = (this._data || '') + data; 24095 } 24096 } else { 24097 this._data = data; 24098 } 24099 24100 if (!obj || isHost(data)) return this; 24101 if (!type) this.type('json'); 24102 return this; 24103 }; 24104 24105 /** 24106 * Invoke the callback with `err` and `res` 24107 * and handle arity check. 24108 * 24109 * @param {Error} err 24110 * @param {Response} res 24111 * @api private 24112 */ 24113 24114 Request.prototype.callback = function(err, res){ 24115 var fn = this._callback; 24116 this.clearTimeout(); 24117 fn(err, res); 24118 }; 24119 24120 /** 24121 * Invoke callback with x-domain error. 24122 * 24123 * @api private 24124 */ 24125 24126 Request.prototype.crossDomainError = function(){ 24127 var err = new Error('Origin is not allowed by Access-Control-Allow-Origin'); 24128 err.crossDomain = true; 24129 this.callback(err); 24130 }; 24131 24132 /** 24133 * Invoke callback with timeout error. 24134 * 24135 * @api private 24136 */ 24137 24138 Request.prototype.timeoutError = function(){ 24139 var timeout = this._timeout; 24140 var err = new Error('timeout of ' + timeout + 'ms exceeded'); 24141 err.timeout = timeout; 24142 this.callback(err); 24143 }; 24144 24145 /** 24146 * Enable transmission of cookies with x-domain requests. 24147 * 24148 * Note that for this to work the origin must not be 24149 * using "Access-Control-Allow-Origin" with a wildcard, 24150 * and also must set "Access-Control-Allow-Credentials" 24151 * to "true". 24152 * 24153 * @api public 24154 */ 24155 24156 Request.prototype.withCredentials = function(){ 24157 this._withCredentials = true; 24158 return this; 24159 }; 24160 24161 /** 24162 * Initiate request, invoking callback `fn(res)` 24163 * with an instanceof `Response`. 24164 * 24165 * @param {Function} fn 24166 * @return {Request} for chaining 24167 * @api public 24168 */ 24169 24170 Request.prototype.end = function(fn){ 24171 var self = this; 24172 var xhr = this.xhr = request.getXHR(); 24173 var query = this._query.join('&'); 24174 var timeout = this._timeout; 24175 var data = this._formData || this._data; 24176 24177 // store callback 24178 this._callback = fn || noop; 24179 24180 // state change 24181 xhr.onreadystatechange = function(){ 24182 if (4 != xhr.readyState) return; 24183 24184 // In IE9, reads to any property (e.g. status) off of an aborted XHR will 24185 // result in the error "Could not complete the operation due to error c00c023f" 24186 var status; 24187 try { status = xhr.status } catch(e) { status = 0; } 24188 24189 if (0 == status) { 24190 if (self.timedout) return self.timeoutError(); 24191 if (self.aborted) return; 24192 return self.crossDomainError(); 24193 } 24194 self.emit('end'); 24195 }; 24196 24197 // progress 24198 var handleProgress = function(e){ 24199 if (e.total > 0) { 24200 e.percent = e.loaded / e.total * 100; 24201 } 24202 self.emit('progress', e); 24203 }; 24204 if (this.hasListeners('progress')) { 24205 xhr.onprogress = handleProgress; 24206 } 24207 try { 24208 if (xhr.upload && this.hasListeners('progress')) { 24209 xhr.upload.onprogress = handleProgress; 24210 } 24211 } catch(e) { 24212 // Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist. 24213 // Reported here: 24214 // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context 24215 } 24216 24217 // timeout 24218 if (timeout && !this._timer) { 24219 this._timer = setTimeout(function(){ 24220 self.timedout = true; 24221 self.abort(); 24222 }, timeout); 24223 } 24224 24225 // querystring 24226 if (query) { 24227 query = request.serializeObject(query); 24228 this.url += ~this.url.indexOf('?') 24229 ? '&' + query 24230 : '?' + query; 24231 } 24232 24233 // initiate request 24234 xhr.open(this.method, this.url, true); 24235 24236 // CORS 24237 if (this._withCredentials) xhr.withCredentials = true; 24238 24239 // body 24240 if ('GET' != this.method && 'HEAD' != this.method && 'string' != typeof data && !isHost(data)) { 24241 // serialize stuff 24242 var contentType = this.getHeader('Content-Type'); 24243 var serialize = this._parser || request.serialize[contentType ? contentType.split(';')[0] : '']; 24244 if (serialize) data = serialize(data); 24245 } 24246 24247 // set header fields 24248 for (var field in this.header) { 24249 if (null == this.header[field]) continue; 24250 xhr.setRequestHeader(field, this.header[field]); 24251 } 24252 24253 // send stuff 24254 this.emit('request', this); 24255 24256 // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing) 24257 // We need null here if data is undefined 24258 xhr.send(typeof data !== 'undefined' ? data : null); 24259 return this; 24260 }; 24261 24262 /** 24263 * Faux promise support 24264 * 24265 * @param {Function} fulfill 24266 * @param {Function} reject 24267 * @return {Request} 24268 */ 24269 24270 Request.prototype.then = function (fulfill, reject) { 24271 return this.end(function(err, res) { 24272 err ? reject(err) : fulfill(res); 24273 }); 24274 } 24275 24276 /** 24277 * Expose `Request`. 24278 */ 24279 24280 request.Request = Request; 24281 24282 /** 24283 * Issue a request: 24284 * 24285 * Examples: 24286 * 24287 * request('GET', '/users').end(callback) 24288 * request('/users').end(callback) 24289 * request('/users', callback) 24290 * 24291 * @param {String} method 24292 * @param {String|Function} url or callback 24293 * @return {Request} 24294 * @api public 24295 */ 24296 24297 function request(method, url) { 24298 // callback 24299 if ('function' == typeof url) { 24300 return new Request('GET', method).end(url); 24301 } 24302 24303 // url first 24304 if (1 == arguments.length) { 24305 return new Request('GET', method); 24306 } 24307 24308 return new Request(method, url); 24309 } 24310 24311 /** 24312 * GET `url` with optional callback `fn(res)`. 24313 * 24314 * @param {String} url 24315 * @param {Mixed|Function} data or fn 24316 * @param {Function} fn 24317 * @return {Request} 24318 * @api public 24319 */ 24320 24321 request.get = function(url, data, fn){ 24322 var req = request('GET', url); 24323 if ('function' == typeof data) fn = data, data = null; 24324 if (data) req.query(data); 24325 if (fn) req.end(fn); 24326 return req; 24327 }; 24328 24329 /** 24330 * HEAD `url` with optional callback `fn(res)`. 24331 * 24332 * @param {String} url 24333 * @param {Mixed|Function} data or fn 24334 * @param {Function} fn 24335 * @return {Request} 24336 * @api public 24337 */ 24338 24339 request.head = function(url, data, fn){ 24340 var req = request('HEAD', url); 24341 if ('function' == typeof data) fn = data, data = null; 24342 if (data) req.send(data); 24343 if (fn) req.end(fn); 24344 return req; 24345 }; 24346 24347 /** 24348 * DELETE `url` with optional callback `fn(res)`. 24349 * 24350 * @param {String} url 24351 * @param {Function} fn 24352 * @return {Request} 24353 * @api public 24354 */ 24355 24356 function del(url, fn){ 24357 var req = request('DELETE', url); 24358 if (fn) req.end(fn); 24359 return req; 24360 }; 24361 24362 request.del = del; 24363 request.delete = del; 24364 24365 /** 24366 * PATCH `url` with optional `data` and callback `fn(res)`. 24367 * 24368 * @param {String} url 24369 * @param {Mixed} data 24370 * @param {Function} fn 24371 * @return {Request} 24372 * @api public 24373 */ 24374 24375 request.patch = function(url, data, fn){ 24376 var req = request('PATCH', url); 24377 if ('function' == typeof data) fn = data, data = null; 24378 if (data) req.send(data); 24379 if (fn) req.end(fn); 24380 return req; 24381 }; 24382 24383 /** 24384 * POST `url` with optional `data` and callback `fn(res)`. 24385 * 24386 * @param {String} url 24387 * @param {Mixed} data 24388 * @param {Function} fn 24389 * @return {Request} 24390 * @api public 24391 */ 24392 24393 request.post = function(url, data, fn){ 24394 var req = request('POST', url); 24395 if ('function' == typeof data) fn = data, data = null; 24396 if (data) req.send(data); 24397 if (fn) req.end(fn); 24398 return req; 24399 }; 24400 24401 /** 24402 * PUT `url` with optional `data` and callback `fn(res)`. 24403 * 24404 * @param {String} url 24405 * @param {Mixed|Function} data or fn 24406 * @param {Function} fn 24407 * @return {Request} 24408 * @api public 24409 */ 24410 24411 request.put = function(url, data, fn){ 24412 var req = request('PUT', url); 24413 if ('function' == typeof data) fn = data, data = null; 24414 if (data) req.send(data); 24415 if (fn) req.end(fn); 24416 return req; 24417 }; 24418 24419 /** 24420 * Expose `request`. 24421 */ 24422 24423 module.exports = request; 24424 24425 },{"emitter":163,"reduce":164}],163:[function(require,module,exports){ 24426 24427 /** 24428 * Expose `Emitter`. 24429 */ 24430 24431 module.exports = Emitter; 24432 24433 /** 24434 * Initialize a new `Emitter`. 24435 * 24436 * @api public 24437 */ 24438 24439 function Emitter(obj) { 24440 if (obj) return mixin(obj); 24441 }; 24442 24443 /** 24444 * Mixin the emitter properties. 24445 * 24446 * @param {Object} obj 24447 * @return {Object} 24448 * @api private 24449 */ 24450 24451 function mixin(obj) { 24452 for (var key in Emitter.prototype) { 24453 obj[key] = Emitter.prototype[key]; 24454 } 24455 return obj; 24456 } 24457 24458 /** 24459 * Listen on the given `event` with `fn`. 24460 * 24461 * @param {String} event 24462 * @param {Function} fn 24463 * @return {Emitter} 24464 * @api public 24465 */ 24466 24467 Emitter.prototype.on = 24468 Emitter.prototype.addEventListener = function(event, fn){ 24469 this._callbacks = this._callbacks || {}; 24470 (this._callbacks[event] = this._callbacks[event] || []) 24471 .push(fn); 24472 return this; 24473 }; 24474 24475 /** 24476 * Adds an `event` listener that will be invoked a single 24477 * time then automatically removed. 24478 * 24479 * @param {String} event 24480 * @param {Function} fn 24481 * @return {Emitter} 24482 * @api public 24483 */ 24484 24485 Emitter.prototype.once = function(event, fn){ 24486 var self = this; 24487 this._callbacks = this._callbacks || {}; 24488 24489 function on() { 24490 self.off(event, on); 24491 fn.apply(this, arguments); 24492 } 24493 24494 on.fn = fn; 24495 this.on(event, on); 24496 return this; 24497 }; 24498 24499 /** 24500 * Remove the given callback for `event` or all 24501 * registered callbacks. 24502 * 24503 * @param {String} event 24504 * @param {Function} fn 24505 * @return {Emitter} 24506 * @api public 24507 */ 24508 24509 Emitter.prototype.off = 24510 Emitter.prototype.removeListener = 24511 Emitter.prototype.removeAllListeners = 24512 Emitter.prototype.removeEventListener = function(event, fn){ 24513 this._callbacks = this._callbacks || {}; 24514 24515 // all 24516 if (0 == arguments.length) { 24517 this._callbacks = {}; 24518 return this; 24519 } 24520 24521 // specific event 24522 var callbacks = this._callbacks[event]; 24523 if (!callbacks) return this; 24524 24525 // remove all handlers 24526 if (1 == arguments.length) { 24527 delete this._callbacks[event]; 24528 return this; 24529 } 24530 24531 // remove specific handler 24532 var cb; 24533 for (var i = 0; i < callbacks.length; i++) { 24534 cb = callbacks[i]; 24535 if (cb === fn || cb.fn === fn) { 24536 callbacks.splice(i, 1); 24537 break; 24538 } 24539 } 24540 return this; 24541 }; 24542 24543 /** 24544 * Emit `event` with the given args. 24545 * 24546 * @param {String} event 24547 * @param {Mixed} ... 24548 * @return {Emitter} 24549 */ 24550 24551 Emitter.prototype.emit = function(event){ 24552 this._callbacks = this._callbacks || {}; 24553 var args = [].slice.call(arguments, 1) 24554 , callbacks = this._callbacks[event]; 24555 24556 if (callbacks) { 24557 callbacks = callbacks.slice(0); 24558 for (var i = 0, len = callbacks.length; i < len; ++i) { 24559 callbacks[i].apply(this, args); 24560 } 24561 } 24562 24563 return this; 24564 }; 24565 24566 /** 24567 * Return array of callbacks for `event`. 24568 * 24569 * @param {String} event 24570 * @return {Array} 24571 * @api public 24572 */ 24573 24574 Emitter.prototype.listeners = function(event){ 24575 this._callbacks = this._callbacks || {}; 24576 return this._callbacks[event] || []; 24577 }; 24578 24579 /** 24580 * Check if this emitter has `event` handlers. 24581 * 24582 * @param {String} event 24583 * @return {Boolean} 24584 * @api public 24585 */ 24586 24587 Emitter.prototype.hasListeners = function(event){ 24588 return !! this.listeners(event).length; 24589 }; 24590 24591 },{}],164:[function(require,module,exports){ 24592 24593 /** 24594 * Reduce `arr` with `fn`. 24595 * 24596 * @param {Array} arr 24597 * @param {Function} fn 24598 * @param {Mixed} initial 24599 * 24600 * TODO: combatible error handling? 24601 */ 24602 24603 module.exports = function(arr, fn, initial){ 24604 var idx = 0; 24605 var len = arr.length; 24606 var curr = arguments.length == 3 24607 ? initial 24608 : arr[idx++]; 24609 24610 while (idx < len) { 24611 curr = fn.call(null, curr, arr[idx], ++idx, arr); 24612 } 24613 24614 return curr; 24615 }; 24616 },{}]},{},[1])(1) 24617 }); 24618 //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","index.js","lib/auth.js","lib/client.js","lib/helpers.js","lib/http.js","lib/resolver.js","lib/schema-markup.js","lib/spec-converter.js","lib/types/model.js","lib/types/operation.js","lib/types/operationGroup.js","node_modules/browserify/node_modules/browser-resolve/empty.js","node_modules/browserify/node_modules/process/browser.js","node_modules/btoa/index.js","node_modules/buffer/index.js","node_modules/buffer/node_modules/base64-js/lib/b64.js","node_modules/buffer/node_modules/ieee754/index.js","node_modules/buffer/node_modules/is-array/index.js","node_modules/cookiejar/cookiejar.js","node_modules/js-yaml/index.js","node_modules/js-yaml/lib/js-yaml.js","node_modules/js-yaml/lib/js-yaml/common.js","node_modules/js-yaml/lib/js-yaml/dumper.js","node_modules/js-yaml/lib/js-yaml/exception.js","node_modules/js-yaml/lib/js-yaml/loader.js","node_modules/js-yaml/lib/js-yaml/mark.js","node_modules/js-yaml/lib/js-yaml/schema.js","node_modules/js-yaml/lib/js-yaml/schema/core.js","node_modules/js-yaml/lib/js-yaml/schema/default_full.js","node_modules/js-yaml/lib/js-yaml/schema/default_safe.js","node_modules/js-yaml/lib/js-yaml/schema/failsafe.js","node_modules/js-yaml/lib/js-yaml/schema/json.js","node_modules/js-yaml/lib/js-yaml/type.js","node_modules/js-yaml/lib/js-yaml/type/binary.js","node_modules/js-yaml/lib/js-yaml/type/bool.js","node_modules/js-yaml/lib/js-yaml/type/float.js","node_modules/js-yaml/lib/js-yaml/type/int.js","node_modules/js-yaml/lib/js-yaml/type/js/function.js","node_modules/js-yaml/lib/js-yaml/type/js/regexp.js","node_modules/js-yaml/lib/js-yaml/type/js/undefined.js","node_modules/js-yaml/lib/js-yaml/type/map.js","node_modules/js-yaml/lib/js-yaml/type/merge.js","node_modules/js-yaml/lib/js-yaml/type/null.js","node_modules/js-yaml/lib/js-yaml/type/omap.js","node_modules/js-yaml/lib/js-yaml/type/pairs.js","node_modules/js-yaml/lib/js-yaml/type/seq.js","node_modules/js-yaml/lib/js-yaml/type/set.js","node_modules/js-yaml/lib/js-yaml/type/str.js","node_modules/js-yaml/lib/js-yaml/type/timestamp.js","node_modules/js-yaml/node_modules/esprima/esprima.js","node_modules/js-yaml/node_modules/inherit/index.js","node_modules/js-yaml/node_modules/inherit/lib/inherit.js","node_modules/lodash-compat/array/indexOf.js","node_modules/lodash-compat/array/last.js","node_modules/lodash-compat/chain/lodash.js","node_modules/lodash-compat/collection/each.js","node_modules/lodash-compat/collection/find.js","node_modules/lodash-compat/collection/forEach.js","node_modules/lodash-compat/collection/includes.js","node_modules/lodash-compat/collection/map.js","node_modules/lodash-compat/date/now.js","node_modules/lodash-compat/function/bind.js","node_modules/lodash-compat/function/restParam.js","node_modules/lodash-compat/internal/LazyWrapper.js","node_modules/lodash-compat/internal/LodashWrapper.js","node_modules/lodash-compat/internal/arrayCopy.js","node_modules/lodash-compat/internal/arrayEach.js","node_modules/lodash-compat/internal/arrayMap.js","node_modules/lodash-compat/internal/arraySome.js","node_modules/lodash-compat/internal/baseAssign.js","node_modules/lodash-compat/internal/baseCallback.js","node_modules/lodash-compat/internal/baseClone.js","node_modules/lodash-compat/internal/baseCopy.js","node_modules/lodash-compat/internal/baseCreate.js","node_modules/lodash-compat/internal/baseEach.js","node_modules/lodash-compat/internal/baseFind.js","node_modules/lodash-compat/internal/baseFindIndex.js","node_modules/lodash-compat/internal/baseFor.js","node_modules/lodash-compat/internal/baseForIn.js","node_modules/lodash-compat/internal/baseForOwn.js","node_modules/lodash-compat/internal/baseGet.js","node_modules/lodash-compat/internal/baseIndexOf.js","node_modules/lodash-compat/internal/baseIsEqual.js","node_modules/lodash-compat/internal/baseIsEqualDeep.js","node_modules/lodash-compat/internal/baseIsMatch.js","node_modules/lodash-compat/internal/baseLodash.js","node_modules/lodash-compat/internal/baseMap.js","node_modules/lodash-compat/internal/baseMatches.js","node_modules/lodash-compat/internal/baseMatchesProperty.js","node_modules/lodash-compat/internal/baseProperty.js","node_modules/lodash-compat/internal/basePropertyDeep.js","node_modules/lodash-compat/internal/baseSetData.js","node_modules/lodash-compat/internal/baseSlice.js","node_modules/lodash-compat/internal/baseToString.js","node_modules/lodash-compat/internal/baseValues.js","node_modules/lodash-compat/internal/binaryIndex.js","node_modules/lodash-compat/internal/binaryIndexBy.js","node_modules/lodash-compat/internal/bindCallback.js","node_modules/lodash-compat/internal/bufferClone.js","node_modules/lodash-compat/internal/composeArgs.js","node_modules/lodash-compat/internal/composeArgsRight.js","node_modules/lodash-compat/internal/createBaseEach.js","node_modules/lodash-compat/internal/createBaseFor.js","node_modules/lodash-compat/internal/createBindWrapper.js","node_modules/lodash-compat/internal/createCtorWrapper.js","node_modules/lodash-compat/internal/createFind.js","node_modules/lodash-compat/internal/createForEach.js","node_modules/lodash-compat/internal/createHybridWrapper.js","node_modules/lodash-compat/internal/createPartialWrapper.js","node_modules/lodash-compat/internal/createWrapper.js","node_modules/lodash-compat/internal/equalArrays.js","node_modules/lodash-compat/internal/equalByTag.js","node_modules/lodash-compat/internal/equalObjects.js","node_modules/lodash-compat/internal/getData.js","node_modules/lodash-compat/internal/getFuncName.js","node_modules/lodash-compat/internal/getLength.js","node_modules/lodash-compat/internal/getMatchData.js","node_modules/lodash-compat/internal/getNative.js","node_modules/lodash-compat/internal/indexOfNaN.js","node_modules/lodash-compat/internal/initCloneArray.js","node_modules/lodash-compat/internal/initCloneByTag.js","node_modules/lodash-compat/internal/initCloneObject.js","node_modules/lodash-compat/internal/isArrayLike.js","node_modules/lodash-compat/internal/isHostObject.js","node_modules/lodash-compat/internal/isIndex.js","node_modules/lodash-compat/internal/isIterateeCall.js","node_modules/lodash-compat/internal/isKey.js","node_modules/lodash-compat/internal/isLaziable.js","node_modules/lodash-compat/internal/isLength.js","node_modules/lodash-compat/internal/isObjectLike.js","node_modules/lodash-compat/internal/isStrictComparable.js","node_modules/lodash-compat/internal/mergeData.js","node_modules/lodash-compat/internal/metaMap.js","node_modules/lodash-compat/internal/realNames.js","node_modules/lodash-compat/internal/reorder.js","node_modules/lodash-compat/internal/replaceHolders.js","node_modules/lodash-compat/internal/setData.js","node_modules/lodash-compat/internal/shimKeys.js","node_modules/lodash-compat/internal/toObject.js","node_modules/lodash-compat/internal/toPath.js","node_modules/lodash-compat/internal/wrapperClone.js","node_modules/lodash-compat/lang/cloneDeep.js","node_modules/lodash-compat/lang/isArguments.js","node_modules/lodash-compat/lang/isArray.js","node_modules/lodash-compat/lang/isEmpty.js","node_modules/lodash-compat/lang/isFunction.js","node_modules/lodash-compat/lang/isNative.js","node_modules/lodash-compat/lang/isObject.js","node_modules/lodash-compat/lang/isPlainObject.js","node_modules/lodash-compat/lang/isString.js","node_modules/lodash-compat/lang/isTypedArray.js","node_modules/lodash-compat/lang/isUndefined.js","node_modules/lodash-compat/object/keys.js","node_modules/lodash-compat/object/keysIn.js","node_modules/lodash-compat/object/pairs.js","node_modules/lodash-compat/object/values.js","node_modules/lodash-compat/support.js","node_modules/lodash-compat/utility/identity.js","node_modules/lodash-compat/utility/noop.js","node_modules/lodash-compat/utility/property.js","node_modules/q/q.js","node_modules/superagent/lib/client.js","node_modules/superagent/node_modules/component-emitter/index.js","node_modules/superagent/node_modules/reduce-component/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/rBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACloBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC99BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7/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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACh1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1iDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7mLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7HA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/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;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACngEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7pCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","'use strict';\n\nvar auth = require('./lib/auth');\nvar helpers = require('./lib/helpers');\nvar SwaggerClient = require('./lib/client');\nvar deprecationWrapper = function (url, options) {\n  helpers.log('This is deprecated, use \"new SwaggerClient\" instead.');\n\n  return new SwaggerClient(url, options);\n};\n\n/* Here for IE8 Support */\nif (!Array.prototype.indexOf) {\n  Array.prototype.indexOf = function(obj, start) {\n    for (var i = (start || 0), j = this.length; i < j; i++) {\n      if (this[i] === obj) { return i; }\n    }\n    return -1;\n  };\n}\n\n/* Here for IE8 Support */\nif (!String.prototype.trim) {\n  String.prototype.trim = function () {\n    return this.replace(/^\\s+|\\s+$/g, '');\n  };\n}\n\n/* Here for node 10.x support */\nif (!String.prototype.endsWith) {\n  String.prototype.endsWith = function(suffix) {\n    return this.indexOf(suffix, this.length - suffix.length) !== -1;\n  };\n}\n\nmodule.exports = SwaggerClient;\n\nSwaggerClient.ApiKeyAuthorization = auth.ApiKeyAuthorization;\nSwaggerClient.PasswordAuthorization = auth.PasswordAuthorization;\nSwaggerClient.CookieAuthorization = auth.CookieAuthorization;\nSwaggerClient.SwaggerApi = deprecationWrapper;\nSwaggerClient.SwaggerClient = deprecationWrapper;\nSwaggerClient.SchemaMarkup = require('./lib/schema-markup');\n","'use strict';\n\nvar helpers = require('./helpers');\nvar btoa = require('btoa'); // jshint ignore:line\nvar CookieJar = require('cookiejar').CookieJar;\nvar _ = {\n  each: require('lodash-compat/collection/each'),\n  includes: require('lodash-compat/collection/includes'),\n  isObject: require('lodash-compat/lang/isObject'),\n  isArray: require('lodash-compat/lang/isArray')\n};\n\n/**\n * SwaggerAuthorizations applys the correct authorization to an operation being executed\n */\nvar SwaggerAuthorizations = module.exports.SwaggerAuthorizations = function (authz) {\n  this.authz = authz || {};\n};\n\n/**\n * Add auths to the hash\n * Will overwrite any existing\n *\n */\nSwaggerAuthorizations.prototype.add = function (name, auth) {\n  if(_.isObject(name)) {\n    for (var key in name) {\n      this.authz[key] = name[key];\n    }\n  } else if(typeof name === 'string' ){\n    this.authz[name] = auth;\n  }\n\n  return auth;\n};\n\nSwaggerAuthorizations.prototype.remove = function (name) {\n  return delete this.authz[name];\n};\n\nSwaggerAuthorizations.prototype.apply = function (obj, securities) {\n  var status = true;\n  var applyAll = !securities;\n  var flattenedSecurities = [];\n\n  // Securities could be [ {} ]\n  _.each(securities, function (obj, key) {\n\n    // Make sure we account for securities being [ str ]\n    if(typeof key === 'string') {\n      flattenedSecurities.push(key);\n    }\n\n    // Flatten keys in to our array\n    _.each(obj, function (val, key) {\n      flattenedSecurities.push(key);\n    });\n  });\n\n  _.each(this.authz, function (auth, authName) {\n    if(applyAll || _.includes(flattenedSecurities, authName)) {\n      var newStatus = auth.apply(obj);\n      status = status && !!newStatus; // logical ORs regarding status\n    }\n  });\n\n  return status;\n};\n\n/**\n * ApiKeyAuthorization allows a query param or header to be injected\n */\nvar ApiKeyAuthorization = module.exports.ApiKeyAuthorization = function (name, value, type) {\n  this.name = name;\n  this.value = value;\n  this.type = type;\n};\n\nApiKeyAuthorization.prototype.apply = function (obj) {\n  if (this.type === 'query') {\n    // see if already applied.  If so, don't do it again\n\n    var qp;\n    if (obj.url.indexOf('?') > 0) {\n      qp = obj.url.substring(obj.url.indexOf('?') + 1);\n      var parts = qp.split('&');\n      if(parts && parts.length > 0) {\n        for(var i = 0; i < parts.length; i++) {\n          var kv = parts[i].split('=');\n          if(kv && kv.length > 0) {\n            if (kv[0] === this.name) {\n              // skip it\n              return false;\n            }\n          }\n        }\n      }\n    }\n\n    if (obj.url.indexOf('?') > 0) {\n      obj.url = obj.url + '&' + this.name + '=' + this.value;\n    } else {\n      obj.url = obj.url + '?' + this.name + '=' + this.value;\n    }\n\n    return true;\n  } else if (this.type === 'header') {\n    if(typeof obj.headers[this.name] === 'undefined') {\n      obj.headers[this.name] = this.value;\n    }\n\n    return true;\n  }\n};\n\nvar CookieAuthorization = module.exports.CookieAuthorization = function (cookie) {\n  this.cookie = cookie;\n};\n\nCookieAuthorization.prototype.apply = function (obj) {\n  obj.cookieJar = obj.cookieJar || new CookieJar();\n  obj.cookieJar.setCookie(this.cookie);\n\n  return true;\n};\n\n/**\n * Password Authorization is a basic auth implementation\n */\nvar PasswordAuthorization = module.exports.PasswordAuthorization = function (username, password) {\n  if (arguments.length === 3) {\n    helpers.log('PasswordAuthorization: the \\'name\\' argument has been removed, pass only username and password');\n    username = arguments[1];\n    password = arguments[2];\n  }\n  this.username = username;\n  this.password = password;\n};\n\nPasswordAuthorization.prototype.apply = function (obj) {\n  if(typeof obj.headers.Authorization === 'undefined') {\n    obj.headers.Authorization = 'Basic ' + btoa(this.username + ':' + this.password);\n  }\n\n  return true;\n};\n","'use strict';\n\nvar _ = {\n  bind: require('lodash-compat/function/bind'),\n  cloneDeep: require('lodash-compat/lang/cloneDeep'),\n  find: require('lodash-compat/collection/find'),\n  forEach: require('lodash-compat/collection/forEach'),\n  indexOf: require('lodash-compat/array/indexOf'),\n  isArray: require('lodash-compat/lang/isArray'),\n  isObject: require('lodash-compat/lang/isObject'),\n  isFunction: require('lodash-compat/lang/isFunction'),\n  isPlainObject: require('lodash-compat/lang/isPlainObject'),\n  isUndefined: require('lodash-compat/lang/isUndefined')\n};\nvar auth = require('./auth');\nvar helpers = require('./helpers');\nvar Model = require('./types/model');\nvar Operation = require('./types/operation');\nvar OperationGroup = require('./types/operationGroup');\nvar Resolver = require('./resolver');\nvar SwaggerHttp = require('./http');\nvar SwaggerSpecConverter = require('./spec-converter');\nvar Q = require('q');\n\n// We have to keep track of the function/property names to avoid collisions for tag names which are used to allow the\n// following usage: 'client.{tagName}'\nvar reservedClientTags = [\n  'apis',\n  'authorizationScheme',\n  'authorizations',\n  'basePath',\n  'build',\n  'buildFrom1_1Spec',\n  'buildFrom1_2Spec',\n  'buildFromSpec',\n  'clientAuthorizations',\n  'convertInfo',\n  'debug',\n  'defaultErrorCallback',\n  'defaultSuccessCallback',\n  'enableCookies',\n  'fail',\n  'failure',\n  'finish',\n  'help',\n  'idFromOp',\n  'info',\n  'initialize',\n  'isBuilt',\n  'isValid',\n  'modelPropertyMacro',\n  'models',\n  'modelsArray',\n  'options',\n  'parameterMacro',\n  'parseUri',\n  'progress',\n  'resourceCount',\n  'sampleModels',\n  'selfReflect',\n  'setConsolidatedModels',\n  'spec',\n  'supportedSubmitMethods',\n  'swaggerRequestHeaders',\n  'tagFromLabel',\n  'title',\n  'url',\n  'useJQuery'\n];\n// We have to keep track of the function/property names to avoid collisions for tag names which are used to allow the\n// following usage: 'client.apis.{tagName}'\nvar reservedApiTags = [\n  'apis',\n  'asCurl',\n  'description',\n  'externalDocs',\n  'help',\n  'label',\n  'name',\n  'operation',\n  'operations',\n  'operationsArray',\n  'path',\n  'tag'\n];\nvar supportedOperationMethods = ['delete', 'get', 'head', 'options', 'patch', 'post', 'put'];\nvar SwaggerClient = module.exports = function (url, options) {\n  this.authorizations = null;\n  this.authorizationScheme = null;\n  this.basePath = null;\n  this.debug = false;\n  this.enableCookies = false;\n  this.info = null;\n  this.isBuilt = false;\n  this.isValid = false;\n  this.modelsArray = [];\n  this.resourceCount = 0;\n  this.url = null;\n  this.useJQuery = false;\n  this.swaggerObject = {};\n  this.deferredClient = Q.defer();\n\n  this.clientAuthorizations = new auth.SwaggerAuthorizations();\n\n  if (typeof url !== 'undefined') {\n    return this.initialize(url, options);\n  } else {\n    return this;\n  }\n};\n\nSwaggerClient.prototype.initialize = function (url, options) {\n  this.models = {};\n  this.sampleModels = {};\n\n  if (typeof url === 'string') {\n    this.url = url;\n  } else if (_.isObject(url)) {\n    options = url;\n    this.url = options.url;\n  }\n\n  options = options || {};\n  this.clientAuthorizations.add(options.authorizations);\n  this.swaggerRequestHeaders = options.swaggerRequestHeaders || 'application/json;charset=utf-8,*/*';\n  this.defaultSuccessCallback = options.defaultSuccessCallback || null;\n  this.defaultErrorCallback = options.defaultErrorCallback || null;\n  this.modelPropertyMacro = options.modelPropertyMacro || null;\n  this.parameterMacro = options.parameterMacro || null;\n  this.usePromise = options.usePromise || null;\n\n  if (typeof options.success === 'function') {\n    this.success = options.success;\n  }\n\n  if (options.useJQuery) {\n    this.useJQuery = options.useJQuery;\n  }\n\n  if (options.enableCookies) {\n    this.enableCookies = options.enableCookies;\n  }\n\n  this.options = options || {};\n\n  this.supportedSubmitMethods = options.supportedSubmitMethods || [];\n  this.failure = options.failure || function (err) { throw err; };\n  this.progress = options.progress || function () {};\n  this.spec = _.cloneDeep(options.spec); // Clone so we do not alter the provided document\n\n  if (options.scheme) {\n    this.scheme = options.scheme;\n  }\n\n  if (this.usePromise || typeof options.success === 'function') {\n    this.ready = true;\n    return this.build();\n  }\n};\n\nSwaggerClient.prototype.build = function (mock) {\n  if (this.isBuilt) {\n    return this;\n  }\n\n  var self = this;\n\n  this.progress('fetching resource list: ' + this.url + '; Please wait.');\n\n  var obj = {\n    useJQuery: this.useJQuery,\n    url: this.url,\n    method: 'get',\n    headers: {\n      accept: this.swaggerRequestHeaders\n    },\n    on: {\n      error: function (response) {\n        if (self.url.substring(0, 4) !== 'http') {\n          return self.fail('Please specify the protocol for ' + self.url);\n        } else if (response.status === 0) {\n          return self.fail('Can\\'t read from server.  It may not have the appropriate access-control-origin settings.');\n        } else if (response.status === 404) {\n          return self.fail('Can\\'t read swagger JSON from ' + self.url);\n        } else {\n          return self.fail(response.status + ' : ' + response.statusText + ' ' + self.url);\n        }\n      },\n      response: function (resp) {\n\n        var responseObj = resp.obj;\n        if(!responseObj) {\n          return self.fail('failed to parse JSON/YAML response');\n        }\n\n        self.swaggerVersion = responseObj.swaggerVersion;\n        self.swaggerObject = responseObj;\n\n        if (responseObj.swagger && parseInt(responseObj.swagger) === 2) {\n          self.swaggerVersion = responseObj.swagger;\n\n          new Resolver().resolve(responseObj, self.url, self.buildFromSpec, self);\n\n          self.isValid = true;\n        } else {\n          var converter = new SwaggerSpecConverter();\n          self.oldSwaggerObject = self.swaggerObject;\n\n          converter.setDocumentationLocation(self.url);\n          converter.convert(responseObj, self.clientAuthorizations, self.options, function(spec) {\n            self.swaggerObject = spec;\n            new Resolver().resolve(spec, self.url, self.buildFromSpec, self);\n            self.isValid = true;\n          });\n        }\n      }\n    }\n  };\n\n  if (this.spec) {\n    self.swaggerObject = this.spec;\n    setTimeout(function () {\n      new Resolver().resolve(self.spec, self.buildFromSpec, self);\n    }, 10);\n  } else {\n    this.clientAuthorizations.apply(obj);\n\n    if (mock) {\n      return obj;\n    }\n\n    new SwaggerHttp().execute(obj, this.options);\n  }\n\n  return (this.usePromise) ? this.deferredClient.promise : this;\n};\n\nSwaggerClient.prototype.buildFromSpec = function (response) {\n  if (this.isBuilt) {\n    return this;\n  }\n\n  this.apis = {};\n  this.apisArray = [];\n  this.basePath = response.basePath || '';\n  this.consumes = response.consumes;\n  this.host = response.host || '';\n  this.info = response.info || {};\n  this.produces = response.produces;\n  this.schemes = response.schemes || [];\n  this.securityDefinitions = response.securityDefinitions;\n  this.title = response.title || '';\n\n  if (response.externalDocs) {\n    this.externalDocs = response.externalDocs;\n  }\n\n  // legacy support\n  this.authSchemes = response.securityDefinitions;\n\n  var definedTags = {};\n  var k;\n\n  if (Array.isArray(response.tags)) {\n    definedTags = {};\n\n    for (k = 0; k < response.tags.length; k++) {\n      var t = response.tags[k];\n      definedTags[t.name] = t;\n    }\n  }\n\n  var location;\n\n  if (typeof this.url === 'string') {\n    location = this.parseUri(this.url);\n    if (typeof this.scheme === 'undefined' && typeof this.schemes === 'undefined' || this.schemes.length === 0) {\n      this.scheme = location.scheme || 'http';\n    } else if (typeof this.scheme === 'undefined') {\n      this.scheme = this.schemes[0] || location.scheme;\n    }\n\n    if (typeof this.host === 'undefined' || this.host === '') {\n      this.host = location.host;\n\n      if (location.port) {\n        this.host = this.host + ':' + location.port;\n      }\n    }\n  }\n  else {\n    if (typeof this.schemes === 'undefined' || this.schemes.length === 0) {\n      this.scheme = 'http';\n    }\n    else if (typeof this.scheme === 'undefined') {\n      this.scheme = this.schemes[0];\n    }\n  }\n\n  this.definitions = response.definitions;\n\n  var key;\n\n  for (key in this.definitions) {\n    var model = new Model(key, this.definitions[key], this.models, this.modelPropertyMacro);\n\n    if (model) {\n      this.models[key] = model;\n    }\n  }\n\n  // get paths, create functions for each operationId\n  var self = this;\n\n  // Bind help to 'client.apis'\n  self.apis.help = _.bind(self.help, self);\n\n  _.forEach(response.paths, function (pathObj, path) {\n    // Only process a path if it's an object\n    if (!_.isPlainObject(pathObj)) {\n      return;\n    }\n\n    _.forEach(supportedOperationMethods, function (method) {\n      var operation = pathObj[method];\n\n      if (_.isUndefined(operation)) {\n        // Operation does not exist\n        return;\n      } else if (!_.isPlainObject(operation)) {\n        // Operation exists but it is not an Operation Object.  Since this is invalid, log it.\n        helpers.log('The \\'' + method + '\\' operation for \\'' + path + '\\' path is not an Operation Object');\n\n        return;\n      }\n\n      var tags = operation.tags;\n\n      if (_.isUndefined(tags) || !_.isArray(tags) || tags.length === 0) {\n        tags = operation.tags = [ 'default' ];\n      }\n\n      var operationId = self.idFromOp(path, method, operation);\n\n      var operationObject = new Operation(self,\n        operation.scheme,\n        operationId,\n        method,\n        path,\n        operation,\n        self.definitions,\n        self.models,\n        self.clientAuthorizations);\n\n      // bind self operation's execute command to the api\n      _.forEach(tags, function (tag) {\n        var clientProperty = _.indexOf(reservedClientTags, tag) > -1 ? '_' + tag : tag;\n        var apiProperty = _.indexOf(reservedApiTags, tag) > -1 ? '_' + tag : tag;\n        var operationGroup = self[clientProperty];\n\n        if (clientProperty !== tag) {\n          helpers.log('The \\'' + tag + '\\' tag conflicts with a SwaggerClient function/property name.  Use \\'client.' +\n                      clientProperty + '\\' or \\'client.apis.' + tag + '\\' instead of \\'client.' + tag + '\\'.');\n        }\n\n        if (apiProperty !== tag) {\n          helpers.log('The \\'' + tag + '\\' tag conflicts with a SwaggerClient operation function/property name.  Use ' +\n                      '\\'client.apis.' + apiProperty + '\\' instead of \\'client.apis.' + tag + '\\'.');\n        }\n\n        if (_.indexOf(reservedApiTags, operationId) > -1) {\n          helpers.log('The \\'' + operationId + '\\' operationId conflicts with a SwaggerClient operation ' +\n                      'function/property name.  Use \\'client.apis.' + apiProperty + '._' + operationId +\n                      '\\' instead of \\'client.apis.' + apiProperty + '.' + operationId + '\\'.');\n\n          operationId = '_' + operationId;\n          operationObject.nickname = operationId; // So 'client.apis.[tag].operationId.help() works properly\n        }\n\n        if (_.isUndefined(operationGroup)) {\n          operationGroup = self[clientProperty] = self.apis[apiProperty] = {};\n\n          operationGroup.operations = {};\n          operationGroup.label = apiProperty;\n          operationGroup.apis = {};\n\n          var tagDef = definedTags[tag];\n\n          if (!_.isUndefined(tagDef)) {\n            operationGroup.description = tagDef.description;\n            operationGroup.externalDocs = tagDef.externalDocs;\n          }\n\n          self[clientProperty].help = _.bind(self.help, operationGroup);\n          self.apisArray.push(new OperationGroup(tag, operationGroup.description, operationGroup.externalDocs, operationObject));\n        }\n\n        operationId = self.makeUniqueOperationId(operationId, self.apis[apiProperty]);\n\n        // Bind tag help\n        if (!_.isFunction(operationGroup.help)) {\n          operationGroup.help = _.bind(self.help, operationGroup);\n        }\n\n        // bind to the apis object\n        self.apis[apiProperty][operationId] = operationGroup[operationId] = _.bind(operationObject.execute,\n                                                                                  operationObject);\n        self.apis[apiProperty][operationId].help = operationGroup[operationId].help = _.bind(operationObject.help,\n                                                                                             operationObject);\n        self.apis[apiProperty][operationId].asCurl = operationGroup[operationId].asCurl = _.bind(operationObject.asCurl,\n                                                                                                 operationObject);\n\n        operationGroup.apis[operationId] = operationGroup.operations[operationId] = operationObject;\n\n        // legacy UI feature\n        var api = _.find(self.apisArray, function (api) {\n          return api.tag === tag;\n        });\n\n        if (api) {\n          api.operationsArray.push(operationObject);\n        }\n      });\n    });\n  });\n\n  this.isBuilt = true;\n\n  if (this.usePromise) {\n    this.isValid = true;\n    this.isBuilt = true;\n    this.deferredClient.resolve(this);\n\n    return this.deferredClient.promise;\n  }\n\n  if (this.success) {\n    this.success();\n  }\n\n  return this;\n};\n\nSwaggerClient.prototype.makeUniqueOperationId = function(operationId, api) {\n  var count = 0;\n  var name = operationId;\n\n  // make unique across this operation group\n  while(true) {\n    var matched = false;\n    _.forEach(api.operations, function (operation) {\n      if(operation.nickname === name) {\n        matched = true;\n      }\n    });\n    if(!matched) {\n      return name;\n    }\n    name = operationId + '_' + count;\n    count ++;\n  }\n\n  return operationId;\n};\n\nSwaggerClient.prototype.parseUri = function (uri) {\n  var urlParseRE = /^(((([^:\\/#\\?]+:)?(?:(\\/\\/)((?:(([^:@\\/#\\?]+)(?:\\:([^:@\\/#\\?]+))?)@)?(([^:\\/#\\?\\]\\[]+|\\[[^\\/\\]@#?]+\\])(?:\\:([0-9]+))?))?)?)?((\\/?(?:[^\\/\\?#]+\\/+)*)([^\\?#]*)))?(\\?[^#]+)?)(#.*)?/;\n  var parts = urlParseRE.exec(uri);\n\n  return {\n    scheme: parts[4] ? parts[4].replace(':','') : undefined,\n    host: parts[11],\n    port: parts[12],\n    path: parts[15]\n  };\n};\n\nSwaggerClient.prototype.help = function (dontPrint) {\n  var output = '';\n\n  if (this instanceof SwaggerClient) {\n    _.forEach(this.apis, function (api, name) {\n      if (_.isPlainObject(api)) {\n        output += 'operations for the \\'' + name + '\\' tag\\n';\n\n        _.forEach(api.operations, function (operation, name) {\n          output += '  * ' + name + ': ' + operation.summary + '\\n';\n        });\n      }\n    });\n  } else if (this instanceof OperationGroup || _.isPlainObject(this)) {\n    output += 'operations for the \\'' + this.label + '\\' tag\\n';\n\n    _.forEach(this.apis, function (operation, name) {\n      output += '  * ' + name + ': ' + operation.summary + '\\n';\n    });\n  }\n\n  if (dontPrint) {\n    return output;\n  } else {\n    helpers.log(output);\n\n    return output;\n  }\n};\n\nSwaggerClient.prototype.tagFromLabel = function (label) {\n  return label;\n};\n\nSwaggerClient.prototype.idFromOp = function (path, httpMethod, op) {\n  if(!op || !op.operationId) {\n    op = op || {};\n    op.operationId = httpMethod + '_' + path;\n  }\n  var opId = op.operationId.replace(/[\\s!@#$%^&*()_+=\\[{\\]};:<>|.\\/?,\\\\'\"\"-]/g, '_') || (path.substring(1) + '_' + httpMethod);\n\n  opId = opId.replace(/((_){2,})/g, '_');\n  opId = opId.replace(/^(_)*/g, '');\n  opId = opId.replace(/([_])*$/g, '');\n\n  return opId;\n};\n\nSwaggerClient.prototype.setHost = function (host) {\n  this.host = host;\n\n  if(this.apis) {\n    _.forEach(this.apis, function(api) {\n      if(api.operations) {\n        _.forEach(api.operations, function(operation) {\n          operation.host = host;\n        });\n      }\n    });\n  }\n};\n\nSwaggerClient.prototype.setBasePath = function (basePath) {\n  this.basePath = basePath;\n\n  if(this.apis) {\n    _.forEach(this.apis, function(api) {\n      if(api.operations) {\n        _.forEach(api.operations, function(operation) {\n          operation.basePath = basePath;\n        });\n      }\n    });\n  }\n};\n\nSwaggerClient.prototype.fail = function (message) {\n  if (this.usePromise) {\n    this.deferredClient.reject(message);\n    return this.deferredClient.promise;\n  } else {\n    if (this.failure) {\n      this.failure(message);\n    }\n    else {\n      this.failure(message);\n    }\n  }\n};\n","(function (process){\n'use strict';\n\nvar _ = {\n  isPlainObject: require('lodash-compat/lang/isPlainObject'),\n  indexOf: require('lodash-compat/array/indexOf')\n};\n\nmodule.exports.__bind = function (fn, me) {\n  return function(){\n    return fn.apply(me, arguments);\n  };\n};\n\nvar log = module.exports.log = function() {\n  // Only log if available and we're not testing\n  if (console && process.env.NODE_ENV !== 'test') {\n    console.log(Array.prototype.slice.call(arguments)[0]);\n  }\n};\n\nmodule.exports.fail = function (message) {\n  log(message);\n};\n\nvar optionHtml = module.exports.optionHtml = function (label, value) {\n  return '<tr><td class=\"optionName\">' + label + ':</td><td>' + value + '</td></tr>';\n};\n\nvar resolveSchema = module.exports.resolveSchema = function (schema) {\n  if (_.isPlainObject(schema.schema)) {\n    schema = resolveSchema(schema.schema);\n  }\n\n  return schema;\n};\n\nvar simpleRef = module.exports.simpleRef = function (name) {\n  if (typeof name === 'undefined') {\n    return null;\n  }\n\n  if (name.indexOf('#/definitions/') === 0) {\n    return name.substring('#/definitions/'.length);\n  } else {\n    return name;\n  }\n};\n\n\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImxpYi9oZWxwZXJzLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBzdHJpY3QnO1xuXG52YXIgXyA9IHtcbiAgaXNQbGFpbk9iamVjdDogcmVxdWlyZSgnbG9kYXNoLWNvbXBhdC9sYW5nL2lzUGxhaW5PYmplY3QnKSxcbiAgaW5kZXhPZjogcmVxdWlyZSgnbG9kYXNoLWNvbXBhdC9hcnJheS9pbmRleE9mJylcbn07XG5cbm1vZHVsZS5leHBvcnRzLl9fYmluZCA9IGZ1bmN0aW9uIChmbiwgbWUpIHtcbiAgcmV0dXJuIGZ1bmN0aW9uKCl7XG4gICAgcmV0dXJuIGZuLmFwcGx5KG1lLCBhcmd1bWVudHMpO1xuICB9O1xufTtcblxudmFyIGxvZyA9IG1vZHVsZS5leHBvcnRzLmxvZyA9IGZ1bmN0aW9uKCkge1xuICAvLyBPbmx5IGxvZyBpZiBhdmFpbGFibGUgYW5kIHdlJ3JlIG5vdCB0ZXN0aW5nXG4gIGlmIChjb25zb2xlICYmIHByb2Nlc3MuZW52Lk5PREVfRU5WICE9PSAndGVzdCcpIHtcbiAgICBjb25zb2xlLmxvZyhBcnJheS5wcm90b3R5cGUuc2xpY2UuY2FsbChhcmd1bWVudHMpWzBdKTtcbiAgfVxufTtcblxubW9kdWxlLmV4cG9ydHMuZmFpbCA9IGZ1bmN0aW9uIChtZXNzYWdlKSB7XG4gIGxvZyhtZXNzYWdlKTtcbn07XG5cbnZhciBvcHRpb25IdG1sID0gbW9kdWxlLmV4cG9ydHMub3B0aW9uSHRtbCA9IGZ1bmN0aW9uIChsYWJlbCwgdmFsdWUpIHtcbiAgcmV0dXJuICc8dHI+PHRkIGNsYXNzPVwib3B0aW9uTmFtZVwiPicgKyBsYWJlbCArICc6PC90ZD48dGQ+JyArIHZhbHVlICsgJzwvdGQ+PC90cj4nO1xufTtcblxudmFyIHJlc29sdmVTY2hlbWEgPSBtb2R1bGUuZXhwb3J0cy5yZXNvbHZlU2NoZW1hID0gZnVuY3Rpb24gKHNjaGVtYSkge1xuICBpZiAoXy5pc1BsYWluT2JqZWN0KHNjaGVtYS5zY2hlbWEpKSB7XG4gICAgc2NoZW1hID0gcmVzb2x2ZVNjaGVtYShzY2hlbWEuc2NoZW1hKTtcbiAgfVxuXG4gIHJldHVybiBzY2hlbWE7XG59O1xuXG52YXIgc2ltcGxlUmVmID0gbW9kdWxlLmV4cG9ydHMuc2ltcGxlUmVmID0gZnVuY3Rpb24gKG5hbWUpIHtcbiAgaWYgKHR5cGVvZiBuYW1lID09PSAndW5kZWZpbmVkJykge1xuICAgIHJldHVybiBudWxsO1xuICB9XG5cbiAgaWYgKG5hbWUuaW5kZXhPZignIy9kZWZpbml0aW9ucy8nKSA9PT0gMCkge1xuICAgIHJldHVybiBuYW1lLnN1YnN0cmluZygnIy9kZWZpbml0aW9ucy8nLmxlbmd0aCk7XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIG5hbWU7XG4gIH1cbn07XG5cbiJdfQ==","'use strict';\n\nvar helpers = require('./helpers');\nvar request = require('superagent');\nvar jsyaml = require('js-yaml');\nvar _ = {\n  isObject: require('lodash-compat/lang/isObject')\n};\n\n/*\n * JQueryHttpClient is a light-weight, node or browser HTTP client\n */\nvar JQueryHttpClient = function () {};\n\n/*\n * SuperagentHttpClient is a light-weight, node or browser HTTP client\n */\nvar SuperagentHttpClient = function () {};\n\n/**\n * SwaggerHttp is a wrapper for executing requests\n */\nvar SwaggerHttp = module.exports = function () {};\n\nSwaggerHttp.prototype.execute = function (obj, opts) {\n  var client;\n\n  if(opts && opts.client) {\n    client = opts.client;\n  }\n  else {\n    client = new SuperagentHttpClient(opts);\n  }\n  client.opts = opts || {};\n\n  // legacy support\n  var hasJQuery = false;\n  if(typeof window !== 'undefined') {\n    if(typeof window.jQuery !== 'undefined') {\n      hasJQuery = true;\n    }\n  }\n  if(this.isInternetExplorer() && (obj.useJQuery === false || !hasJQuery )) {\n    throw new Error('Unsupported configuration! JQuery is required but not available');\n  }\n  if ((obj && obj.useJQuery === true) || this.isInternetExplorer() && hasJQuery) {\n    client = new JQueryHttpClient(opts);\n  }\n\n  var success = obj.on.response;\n\n  var requestInterceptor = function(data) {\n    if(opts && opts.requestInterceptor) {\n      data = opts.requestInterceptor.apply(data);\n    }\n    return data;\n  };\n\n  var responseInterceptor = function(data) {\n    if(opts && opts.responseInterceptor) {\n      data = opts.responseInterceptor.apply(data);\n    }\n    return success(data);\n  };\n\n  obj.on.response = function(data) {\n    responseInterceptor(data);\n  };\n\n\n  if (_.isObject(obj) && _.isObject(obj.body)) {\n    // special processing for file uploads via jquery\n    if (obj.body.type && obj.body.type === 'formData'){\n      obj.contentType = false;\n      obj.processData = false;\n\n      delete obj.headers['Content-Type'];\n    } else {\n      obj.body = JSON.stringify(obj.body);\n    }\n  }\n\n  client.execute(requestInterceptor(obj));\n\n  return (obj.deferred) ? obj.deferred.promise : obj;\n};\n\nSwaggerHttp.prototype.isInternetExplorer = function () {\n  var detectedIE = false;\n\n  if (typeof navigator !== 'undefined' && navigator.userAgent) {\n    var nav = navigator.userAgent.toLowerCase();\n\n    if (nav.indexOf('msie') !== -1) {\n      var version = parseInt(nav.split('msie')[1]);\n\n      if (version <= 8) {\n        detectedIE = true;\n      }\n    }\n  }\n\n  return detectedIE;\n};\n\nJQueryHttpClient.prototype.execute = function (obj) {\n  var jq = this.jQuery || window.jQuery;\n  var cb = obj.on;\n  var request = obj;\n\n  obj.type = obj.method;\n  obj.cache = false;\n  delete obj.useJQuery;\n\n  /*\n  obj.beforeSend = function (xhr) {\n    var key, results;\n    if (obj.headers) {\n      results = [];\n      for (key in obj.headers) {\n        if (key.toLowerCase() === 'content-type') {\n          results.push(obj.contentType = obj.headers[key]);\n        } else if (key.toLowerCase() === 'accept') {\n          results.push(obj.accepts = obj.headers[key]);\n        } else {\n          results.push(xhr.setRequestHeader(key, obj.headers[key]));\n        }\n      }\n      return results;\n    }\n  };*/\n\n  obj.data = obj.body;\n\n  delete obj.body;\n\n  obj.complete = function (response) {\n    var headers = {};\n    var headerArray = response.getAllResponseHeaders().split('\\n');\n\n    for (var i = 0; i < headerArray.length; i++) {\n      var toSplit = headerArray[i].trim();\n\n      if (toSplit.length === 0) {\n        continue;\n      }\n\n      var separator = toSplit.indexOf(':');\n\n      if (separator === -1) {\n        // Name but no value in the header\n        headers[toSplit] = null;\n\n        continue;\n      }\n\n      var name = toSplit.substring(0, separator).trim();\n      var value = toSplit.substring(separator + 1).trim();\n\n      headers[name] = value;\n    }\n\n    var out = {\n      url: request.url,\n      method: request.method,\n      status: response.status,\n      statusText: response.statusText,\n      data: response.responseText,\n      headers: headers\n    };\n\n    try {\n      var possibleObj =  response.responseJSON || jsyaml.safeLoad(response.responseText);\n      out.obj = (typeof possibleObj === 'string') ? {} : possibleObj;\n    } catch (ex) {\n      // do not set out.obj\n      helpers.log('unable to parse JSON/YAML content');\n    }\n\n    // I can throw, or parse null?\n    out.obj = out.obj || null;\n\n    if (response.status >= 200 && response.status < 300) {\n      cb.response(out);\n    } else if (response.status === 0 || (response.status >= 400 && response.status < 599)) {\n      cb.error(out);\n    } else {\n      return cb.response(out);\n    }\n  };\n\n  jq.support.cors = true;\n\n  return jq.ajax(obj);\n};\n\nSuperagentHttpClient.prototype.execute = function (obj) {\n  var method = obj.method.toLowerCase();\n\n  if (method === 'delete') {\n    method = 'del';\n  }\n  var headers = obj.headers || {};\n  var r = request[method](obj.url);\n  var name;\n  for (name in headers) {\n    r.set(name, headers[name]);\n  }\n\n  if (obj.enableCookies) {\n    r.withCredentials();\n  }\n\n  if (obj.body) {\n    r.send(obj.body);\n  }\n\n  if(typeof r.buffer === 'function') {\n    r.buffer(); // force superagent to populate res.text with the raw response data\n  }\n\n  r.end(function (err, res) {\n    res = res || {\n      status: 0,\n      headers: {error: 'no response from server'}\n    };\n    var response = {\n      url: obj.url,\n      method: obj.method,\n      headers: res.headers\n    };\n    var cb;\n\n    if (!err && res.error) {\n      err = res.error;\n    }\n\n    if (err && obj.on && obj.on.error) {\n      response.errObj = err;\n      response.status = res ? res.status : 500;\n      response.statusText = res ? res.text : err.message;\n      if(res.headers && res.headers['content-type']) {\n        if(res.headers['content-type'].indexOf('application/json') >= 0) {\n          try {\n            response.obj = JSON.parse(response.statusText);\n          }\n          catch (e) {\n            response.obj = null;\n          }\n        }\n      }\n      cb = obj.on.error;\n    } else if (res && obj.on && obj.on.response) {\n      var possibleObj;\n\n      // Already parsed by by superagent?\n      if(res.body && Object.keys(res.body).length > 0) {\n        possibleObj = res.body;\n      } else {\n          try {\n            possibleObj = jsyaml.safeLoad(res.text);\n            // can parse into a string... which we don't need running around in the system\n            possibleObj = (typeof possibleObj === 'string') ? null : possibleObj;\n          } catch(e) {\n            helpers.log('cannot parse JSON/YAML content');\n          }\n      }\n\n      // null means we can't parse into object\n      response.obj = (typeof possibleObj === 'object') ? possibleObj : null;\n\n      response.status = res.status;\n      response.statusText = res.text;\n      cb = obj.on.response;\n    }\n    response.data = response.statusText;\n\n    if (cb) {\n      cb(response);\n    }\n  });\n};\n","'use strict';\n\nvar SwaggerHttp = require('./http');\nvar _ = {\n  isObject: require('lodash-compat/lang/isObject'),\n  cloneDeep: require('lodash-compat/lang/cloneDeep'),\n  isArray: require('lodash-compat/lang/isArray')\n};\n\n\n/**\n * Resolves a spec's remote references\n */\nvar Resolver = module.exports = function () {};\n\nResolver.prototype.processAllOf = function(root, name, definition, resolutionTable, unresolvedRefs, spec) {\n  var i, location, property;\n\n  definition['x-resolved-from'] = [ '#/definitions/' + name ];\n  var allOf = definition.allOf;\n  // the refs go first\n  allOf.sort(function(a, b) {\n    if(a.$ref && b.$ref) { return 0; }\n    else if(a.$ref) { return -1; }\n    else { return 1; }\n  });\n  for (i = 0; i < allOf.length; i++) {\n    property = allOf[i];\n    location = '/definitions/' + name + '/allOf';\n    this.resolveInline(root, spec, property, resolutionTable, unresolvedRefs, location);\n  }\n};\n\nResolver.prototype.resolve = function (spec, arg1, arg2, arg3) {\n  this.spec = spec;\n  var root = arg1, callback = arg2, scope = arg3, opts = {}, location, i;\n  if(typeof arg1 === 'function') {\n    root = null;\n    callback = arg1;\n    scope = arg2;\n  }\n  var _root = root;\n  this.scope = (scope || this);\n  this.iteration = this.iteration || 0;\n\n  if(this.scope.options && this.scope.options.requestInterceptor){\n    opts.requestInterceptor = this.scope.options.requestInterceptor;\n  }\n\n  if(this.scope.options && this.scope.options.responseInterceptor){\n    opts.responseInterceptor = this.scope.options.responseInterceptor;\n  }\n\n  var name, path, property, propertyName;\n  var processedCalls = 0, resolvedRefs = {}, unresolvedRefs = {};\n  var resolutionTable = []; // store objects for dereferencing\n\n  spec.definitions = spec.definitions || {};\n  // definitions\n  for (name in spec.definitions) {\n    var definition = spec.definitions[name];\n    for (propertyName in definition.properties) {\n      property = definition.properties[propertyName];\n      if(_.isArray(property.allOf)) {\n        this.processAllOf(root, name, property, resolutionTable, unresolvedRefs, spec);\n      }\n      else {\n        this.resolveTo(root, property, resolutionTable, '/definitions');\n      }\n    }\n\n    if(definition.allOf) {\n      this.processAllOf(root, name, definition, resolutionTable, unresolvedRefs, spec);\n    }\n  }\n\n  // operations\n  for (name in spec.paths) {\n    var method, operation, responseCode;\n    path = spec.paths[name];\n\n    for (method in path) {\n      // operation reference\n      if(method === '$ref') {\n        // location = path[method];\n        location = '/paths' + name;\n        this.resolveInline(root, spec, path, resolutionTable, unresolvedRefs, location);\n      }\n      else {\n        operation = path[method];\n        var sharedParameters = path.parameters || [];\n        var parameters = operation.parameters || [];\n\n        for (i in sharedParameters) {\n          var parameter = sharedParameters[i];\n          parameters.unshift(parameter);\n        }\n        if(method !== 'parameters' && _.isObject(operation)) {\n          operation.parameters = operation.parameters || parameters;\n        }\n\n        for (i in parameters) {\n          var parameter = parameters[i];\n          location = '/paths' + name + '/' + method + '/parameters';\n\n          if (parameter.in === 'body' && parameter.schema) {\n            if(_.isArray(parameter.schema.allOf)) {\n              // move to a definition\n              var modelName = 'inline_model';\n              var name = modelName;\n              var done = false; var counter = 0;\n              while(!done) {\n                if(typeof spec.definitions[name] === 'undefined') {\n                  done = true;\n                  break;\n                }\n                name = modelName + '_' + counter;\n                counter ++;\n              }\n              spec.definitions[name] = { allOf: parameter.schema.allOf };\n              delete parameter.schema.allOf;\n              parameter.schema.$ref = '#/definitions/' + name;\n              this.processAllOf(root, name, spec.definitions[name], resolutionTable, unresolvedRefs, spec);\n            }\n            else {\n              this.resolveTo(root, parameter.schema, resolutionTable, location);\n            }\n          }\n\n          if (parameter.$ref) {\n            // parameter reference\n            this.resolveInline(root, spec, parameter, resolutionTable, unresolvedRefs, parameter.$ref);\n          }\n        }\n\n        for (responseCode in operation.responses) {\n          var response = operation.responses[responseCode];\n          location = '/paths' + name + '/' + method + '/responses/' + responseCode;\n\n          if(_.isObject(response)) {\n            if(response.$ref) {\n              // response reference\n              this.resolveInline(root, spec, response, resolutionTable, unresolvedRefs, location);\n            }\n            if (response.schema) {\n              this.resolveTo(root, response.schema, resolutionTable, location);\n            }\n          }\n        }\n      }\n    }\n    // clear them out to avoid multiple resolutions\n    path.parameters = [];\n  }\n\n  var expectedCalls = 0, toResolve = [];\n  // if the root is same as obj[i].root we can resolve locally\n  var all = resolutionTable;\n\n  var parts;\n  for(i = 0; i < all.length; i++) {\n    var a = all[i];\n    if(root === a.root) {\n      if(a.resolveAs === 'ref') {\n        // resolve any path walking\n        var joined = ((a.root || '') + '/' + a.key).split('/');\n        var normalized = [];\n        var url = '';\n        var k;\n\n        if(a.key.indexOf('../') >= 0) {\n          for(var j = 0; j < joined.length; j++) {\n            if(joined[j] === '..') {\n              normalized = normalized.slice(0, normalized.length-1);\n            }\n            else {\n              normalized.push(joined[j]);\n            }\n          }\n          for(k = 0; k < normalized.length; k ++) {\n            if(k > 0) {\n              url += '/';\n            }\n            url += normalized[k];\n          }\n          // we now have to remote resolve this because the path has changed\n          a.root = url;\n          toResolve.push(a);\n        }\n        else {\n          parts = a.key.split('#');\n          if(parts.length === 2) {\n            if(parts[0].indexOf('http://') === 0 || parts[0].indexOf('https://') === 0) {\n              a.root = parts[0];\n            }\n            location = parts[1].split('/');\n            var r;\n            var s = spec;\n            for(k = 0; k < location.length; k++) {\n              var part = location[k];\n              if(part !== '') {\n                s = s[part];\n                if(typeof s !== 'undefined') {\n                  r = s;\n                }\n                else {\n                  r = null;\n                  break;\n                }\n              }\n            }\n            if(r === null) {\n              // must resolve this too\n              toResolve.push(a);\n            }\n          }\n        }\n      }\n      else {\n        if (a.resolveAs === 'inline') {\n          if(a.key && a.key.indexOf('#') === -1 && a.key.charAt(0) !== '/') {\n            // handle relative schema\n            parts = a.root.split('/');\n            location = '';\n            for(i = 0; i < parts.length - 1; i++) {\n              location += parts[i] + '/';\n            }\n            location += a.key;\n            a.root = location;\n            a.location = '';\n          }\n          toResolve.push(a);\n        }\n      }\n    }\n    else {\n      toResolve.push(a);\n    }\n  }\n  expectedCalls = toResolve.length;\n\n  // resolve anything that is local\n  for(var ii = 0; ii < toResolve.length; ii++) {\n    (function(item, spec, self) {\n      if(item.root === null || item.root === root) {\n        // local resolve\n        self.resolveItem(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, item);\n        processedCalls += 1;\n\n        if(processedCalls === expectedCalls) {\n          self.finish(spec, root, resolutionTable, resolvedRefs, unresolvedRefs, callback, true);\n        }\n      }\n      else {\n        var obj = {\n          useJQuery: false,  // TODO\n          url: item.root,\n          method: 'get',\n          headers: {\n            accept: self.scope.swaggerRequestHeaders || 'application/json'\n          },\n          on: {\n            error: function (error) {\n              processedCalls += 1;\n              unresolvedRefs[item.key] = {\n                root: item.root,\n                location: item.location\n              };\n\n              if (processedCalls === expectedCalls) {\n                self.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback);\n              }\n            },  // jshint ignore:line\n            response: function (response) {\n              var swagger = response.obj;\n              self.resolveItem(swagger, item.root, resolutionTable, resolvedRefs, unresolvedRefs, item);\n              processedCalls += 1;\n\n              if (processedCalls === expectedCalls) {\n                self.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback);\n              }\n            }\n          } // jshint ignore:line\n        };\n\n        if (scope && scope.clientAuthorizations) {\n          scope.clientAuthorizations.apply(obj);\n        }\n\n        new SwaggerHttp().execute(obj, opts);\n      }\n    }(toResolve[ii], spec, this));\n  }\n\n  if (Object.keys(toResolve).length === 0) {\n    this.finish(spec, _root, resolutionTable, resolvedRefs, unresolvedRefs, callback);\n  }\n};\n\nResolver.prototype.resolveItem = function(spec, root, resolutionTable, resolvedRefs, unresolvedRefs, item) {\n  var path = item.location;\n  var location = spec, parts = path.split('/');\n  if(path !== '') {\n    for (var j = 0; j < parts.length; j++) {\n      var segment = parts[j];\n      if (segment.indexOf('~1') !== -1) {\n        segment = parts[j].replace(/~0/g, '~').replace(/~1/g, '/');\n        if (segment.charAt(0) !== '/') {\n          segment = '/' + segment;\n        }\n      }\n      if (typeof location === 'undefined' || location === null) {\n        break;\n      }\n      if (segment === '' && j === (parts.length - 1) && parts.length > 1) {\n        location = null;\n        break;\n      }\n      if (segment.length > 0) {\n        location = location[segment];\n      }\n    }\n  }\n  var resolved = item.key;\n  parts = item.key.split('/');\n  var resolvedName = parts[parts.length-1];\n\n  if(resolvedName.indexOf('#') >= 0) {\n    resolvedName = resolvedName.split('#')[1];\n  }\n\n  if (location !== null && typeof location !== 'undefined') {\n    resolvedRefs[resolved] = {\n      name: resolvedName,\n      obj: location,\n      key: item.key,\n      root: item.root\n    };\n  } else {\n    unresolvedRefs[resolved] = {\n      root: item.root,\n      location: item.location\n    };\n  }\n};\n\nResolver.prototype.finish = function (spec, root, resolutionTable, resolvedRefs, unresolvedRefs, callback, localResolve) {\n  // walk resolution table and replace with resolved refs\n  var ref;\n  for (ref in resolutionTable) {\n    var item = resolutionTable[ref];\n\n    var key = item.key;\n    var resolvedTo = resolvedRefs[key];\n    if (resolvedTo) {\n      spec.definitions = spec.definitions || {};\n      if (item.resolveAs === 'ref') {\n        if (localResolve !== true) {\n          // don't retain root for local definitions\n          for (key in resolvedTo.obj) {\n            var abs = this.retainRoot(resolvedTo.obj[key], item.root);\n          }\n        }\n        spec.definitions[resolvedTo.name] = resolvedTo.obj;\n        item.obj.$ref = '#/definitions/' + resolvedTo.name;\n      } else if (item.resolveAs === 'inline') {\n        var targetObj = item.obj;\n        targetObj['x-resolved-from'] = [ item.key ];\n        delete targetObj.$ref;\n\n        for (key in resolvedTo.obj) {\n          var abs = resolvedTo.obj[key];\n          \n          if (localResolve !== true) {\n            // don't retain root for local definitions\n            abs = this.retainRoot(resolvedTo.obj[key], item.root);\n          }\n          targetObj[key] = abs;\n        }\n      }\n    }\n  }\n  var existingUnresolved = this.countUnresolvedRefs(spec);\n\n  if(existingUnresolved === 0 || this.iteration > 5) {\n    this.resolveAllOf(spec.definitions);\n    callback.call(this.scope, spec, unresolvedRefs);\n  }\n  else {\n    this.iteration += 1;\n    this.resolve(spec, root, callback, this.scope);\n  }\n};\n\nResolver.prototype.countUnresolvedRefs = function(spec) {\n  var i;\n  var refs = this.getRefs(spec);\n  var keys = [];\n  var unresolvedKeys = [];\n  for(i in refs) {\n    if(i.indexOf('#') === 0) {\n      keys.push(i.substring(1));\n    }\n    else {\n      unresolvedKeys.push(i);\n    }\n  }\n\n  // verify possible keys\n  for (i = 0; i < keys.length; i++) {\n    var part = keys[i];\n    var parts = part.split('/');\n    var obj = spec;\n\n    for (var k = 0; k < parts.length; k++) {\n      var key = parts[k];\n      if(key !== '') {\n        obj = obj[key];\n        if(typeof obj === 'undefined') {\n          unresolvedKeys.push(part);\n          break;\n        }\n      }\n    }\n  }\n  return unresolvedKeys.length;\n};\n\nResolver.prototype.getRefs = function(spec, obj) {\n  obj = obj || spec;\n  var output = {};\n  for(var key in obj) {\n    if (!obj.hasOwnProperty(key)) {\n      continue;\n    }\n    var item = obj[key];\n    if(key === '$ref' && typeof item === 'string') {\n      output[item] = null;\n    }\n    else if(_.isObject(item)) {\n      var o = this.getRefs(item);\n      for(var k in o) {\n        output[k] = null;\n      }\n    }\n  }\n  return output;\n};\n\nResolver.prototype.retainRoot = function(obj, root) {\n  // walk object and look for relative $refs\n  for(var key in obj) {\n    var item = obj[key];\n    if(key === '$ref' && typeof item === 'string') {\n      // stop and inspect\n      if(item.indexOf('http://') !== 0 && item.indexOf('https://') !== 0) {\n        if(item.indexOf('#') !== 0) {\n          item = '#' + item;\n        }\n        item = (root || '') + item;\n        obj[key] = item;\n      }\n    }\n    else if(_.isObject(item)) {\n      this.retainRoot(item, root);\n    }\n  }\n  return obj;\n};\n\n/**\n * immediately in-lines local refs, queues remote refs\n * for inline resolution\n */\nResolver.prototype.resolveInline = function (root, spec, property, resolutionTable, unresolvedRefs, location) {\n  var key = property.$ref, ref = property.$ref, i, p, p2, rs;\n  var rootTrimmed = false;\n  if (ref) {\n    if(ref.indexOf('../') === 0) {\n      // reset root\n      p = ref.split('../');\n      p2 = root.split('/');\n      ref = '';\n      for(i = 0; i < p.length; i++) {\n        if(p[i] === '') {\n          p2 = p2.slice(0, p2.length-1);\n        }\n        else {\n          ref += p[i];\n        }\n      }\n      root = '';\n      for(i = 0; i < p2.length - 1; i++) {\n        if(i > 0) { root += '/'; }\n        root += p2[i];\n      }\n      rootTrimmed = true;\n    }\n    if(ref.indexOf('#') >= 0) {\n      if(ref.indexOf('/') === 0) {\n        rs = ref.split('#');\n        p  = root.split('//');\n        p2 = p[1].split('/');\n        root = p[0] + '//' + p2[0] + rs[0];\n        location = rs[1];\n      }\n      else {\n        rs = ref.split('#');\n        if(rs[0] !== '') {\n          p2 = root.split('/');\n          p2 = p2.slice(0, p2.length - 1);\n          if(!rootTrimmed) {\n            root = '';\n            for (var k = 0; k < p2.length; k++) {\n              if(k > 0) { root += '/'; }\n              root += p2[k];\n            }\n          }\n          root += '/' + ref.split('#')[0];\n        }\n        location = rs[1];\n      }\n    }\n    if (ref.indexOf('http') === 0) {\n      if(ref.indexOf('#') >= 0) {\n        root = ref.split('#')[0];\n        location = ref.split('#')[1];\n      }\n      else {\n        root = ref;\n        location = '';\n      }\n      resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location});\n    } else if (ref.indexOf('#') === 0) {\n      location = ref.split('#')[1];\n      resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location});\n    }\n    else {\n      resolutionTable.push({obj: property, resolveAs: 'inline', root: root, key: key, location: location});\n    }\n  }\n  else if (property.type === 'array') {\n    this.resolveTo(root, property.items, resolutionTable, location);\n  }\n};\n\nResolver.prototype.resolveTo = function (root, property, resolutionTable, location) {\n  var sp, i;\n  var ref = property.$ref;\n  var lroot = root;\n  if (typeof ref !== 'undefined') {\n    if(ref.indexOf('#') >= 0) {\n      var parts = ref.split('#');\n\n      // #/definitions/foo\n      // foo.json#/bar\n      if(parts[0] && ref.indexOf('/') === 0) {\n\n      }\n      else if(parts[0] && parts[0].indexOf('http') === 0) {\n        lroot = parts[0];\n        ref = parts[1];\n      }\n      else if(parts[0] && parts[0].length > 0) {\n        // relative file\n        sp = root.split('/');\n        lroot = '';\n        for(i = 0; i < sp.length - 1; i++) {\n          lroot += sp[i] + '/';\n        }\n        lroot += parts[0];\n      }\n      else {\n\n      }\n\n      location = parts[1];\n    }\n    else if (ref.indexOf('http://') === 0 || ref.indexOf('https://') === 0) {\n      lroot = ref;\n      location = '';\n    }\n    else {\n      // relative file\n      sp = root.split('/');\n      lroot = '';\n      for(i = 0; i < sp.length - 1; i++) {\n        lroot += sp[i] + '/';\n      }\n      lroot += ref;\n      location = '';\n    }\n    resolutionTable.push({\n      obj: property, resolveAs: 'ref', root: lroot, key: ref, location: location\n    });\n  } else if (property.type === 'array') {\n    var items = property.items;\n    this.resolveTo(root, items, resolutionTable, location);\n  } else {\n    if(property && property.properties) {\n      var name = this.uniqueName('inline_model');\n      this.spec.definitions[name] = _.cloneDeep(property);\n      property['$ref'] = '#/definitions/' + name;\n      delete property.type;\n      delete property.properties;\n    }\n  }\n};\n\nResolver.prototype.uniqueName = function(base) {\n  var name = base;\n  var count = 0;\n  while(true) {\n    if(!_.isObject(this.spec.definitions[name])) {\n      return name;\n    }\n    name = base + '_' + count;\n    count++;\n  }\n};\n\nResolver.prototype.resolveAllOf = function(spec, obj, depth) {\n  depth = depth || 0;\n  obj = obj || spec;\n  var name;\n  for(var key in obj) {\n    if (!obj.hasOwnProperty(key)) {\n      continue;\n    }\n    var item = obj[key];\n    if(item === null) {\n      throw new TypeError('Swagger 2.0 does not support null types (' + obj + ').  See https://github.com/swagger-api/swagger-spec/issues/229.');\n    }\n    if(typeof item === 'object') {\n      this.resolveAllOf(spec, item, depth + 1);\n    }\n    if(item && typeof item.allOf !== 'undefined') {\n      var allOf = item.allOf;\n      if(_.isArray(allOf)) {\n        var output = _.cloneDeep(item);\n        delete output.allOf;\n\n        output['x-composed'] = true;\n        if (typeof item['x-resolved-from'] !== 'undefined') {\n          output['x-resolved-from'] = item['x-resolved-from'];\n        }\n\n        for(var i = 0; i < allOf.length; i++) {\n          var component = allOf[i];\n          var source = 'self';\n          if(typeof component['x-resolved-from'] !== 'undefined') {\n            source = component['x-resolved-from'][0];\n          }\n\n          for(var part in component) {\n            if(!output.hasOwnProperty(part)) {\n              output[part] = _.cloneDeep(component[part]);\n              if(part === 'properties') {\n                for(name in output[part]) {\n                  output[part][name]['x-resolved-from'] = source;\n                }\n              }\n            }\n            else {\n              if(part === 'properties') {\n                var properties = component[part];\n                for(name in properties) {\n                  output.properties[name] = _.cloneDeep(properties[name]);\n                  var resolvedFrom = properties[name]['x-resolved-from'];\n                  if (typeof resolvedFrom === 'undefined' || resolvedFrom === 'self') {\n                    resolvedFrom = source;\n                  }\n                  output.properties[name]['x-resolved-from'] = resolvedFrom;\n                }\n              }\n              else if(part === 'required') {\n                // merge & dedup the required array\n                var a = output.required.concat(component[part]);\n                for(var k = 0; k < a.length; ++k) {\n                  for(var j = k + 1; j < a.length; ++j) {\n                    if(a[k] === a[j]) { a.splice(j--, 1); }\n                  }\n                }\n                output.required = a;\n              }\n              else if(part === 'x-resolved-from') {\n                output['x-resolved-from'].push(source);\n              }\n              else {\n                // TODO: need to merge this property\n                // console.log('what to do with ' + part)\n              }\n            }\n          }\n        }\n        obj[key] = output;\n      }\n    }\n    if(_.isObject(item)) {\n      this.resolveAllOf(spec, item, depth + 1);\n    }\n  }\n};\n","'use strict';\n\nvar Helpers = require('./helpers');\n\nvar _ = {\n  isPlainObject: require('lodash-compat/lang/isPlainObject'),\n  isUndefined: require('lodash-compat/lang/isUndefined'),\n  isArray: require('lodash-compat/lang/isArray'),\n  isObject: require('lodash-compat/lang/isObject'),\n  isEmpty: require('lodash-compat/lang/isEmpty'),\n  map: require('lodash-compat/collection/map'),\n  indexOf: require('lodash-compat/array/indexOf'),\n  cloneDeep: require('lodash-compat/lang/cloneDeep'),\n  keys: require('lodash-compat/object/keys'),\n  forEach: require('lodash-compat/collection/forEach')\n};\n\nmodule.exports.optionHtml = optionHtml;\nmodule.exports.typeFromJsonSchema = typeFromJsonSchema;\nmodule.exports.getStringSignature = getStringSignature;\nmodule.exports.schemaToHTML = schemaToHTML;\nmodule.exports.schemaToJSON = schemaToJSON;\n\nfunction optionHtml(label, value) {\n  return '<tr><td class=\"optionName\">' + label + ':</td><td>' + value + '</td></tr>';\n}\n\nfunction typeFromJsonSchema(type, format) {\n  var str;\n\n  if (type === 'integer' && format === 'int32') {\n    str = 'integer';\n  } else if (type === 'integer' && format === 'int64') {\n    str = 'long';\n  } else if (type === 'integer' && typeof format === 'undefined') {\n    str = 'long';\n  } else if (type === 'string' && format === 'date-time') {\n    str = 'date-time';\n  } else if (type === 'string' && format === 'date') {\n    str = 'date';\n  } else if (type === 'number' && format === 'float') {\n    str = 'float';\n  } else if (type === 'number' && format === 'double') {\n    str = 'double';\n  } else if (type === 'number' && typeof format === 'undefined') {\n    str = 'double';\n  } else if (type === 'boolean') {\n    str = 'boolean';\n  } else if (type === 'string') {\n    str = 'string';\n  }\n\n  return str;\n}\n\nfunction getStringSignature(obj, baseComponent) {\n  var str = '';\n\n  if (typeof obj.$ref !== 'undefined') {\n    str += Helpers.simpleRef(obj.$ref);\n  } else if (typeof obj.type === 'undefined') {\n    str += 'object';\n  } else if (obj.type === 'array') {\n    if (baseComponent) {\n      str += getStringSignature((obj.items || obj.$ref || {}));\n    } else {\n      str += 'Array[';\n      str += getStringSignature((obj.items || obj.$ref || {}));\n      str += ']';\n    }\n  } else if (obj.type === 'integer' && obj.format === 'int32') {\n    str += 'integer';\n  } else if (obj.type === 'integer' && obj.format === 'int64') {\n    str += 'long';\n  } else if (obj.type === 'integer' && typeof obj.format === 'undefined') {\n    str += 'long';\n  } else if (obj.type === 'string' && obj.format === 'date-time') {\n    str += 'date-time';\n  } else if (obj.type === 'string' && obj.format === 'date') {\n    str += 'date';\n  } else if (obj.type === 'string' && typeof obj.format === 'undefined') {\n    str += 'string';\n  } else if (obj.type === 'number' && obj.format === 'float') {\n    str += 'float';\n  } else if (obj.type === 'number' && obj.format === 'double') {\n    str += 'double';\n  } else if (obj.type === 'number' && typeof obj.format === 'undefined') {\n    str += 'double';\n  } else if (obj.type === 'boolean') {\n    str += 'boolean';\n  } else if (obj.$ref) {\n    str += Helpers.simpleRef(obj.$ref);\n  } else {\n    str += obj.type;\n  }\n\n  return str;\n}\n\nfunction schemaToJSON(schema, models, modelsToIgnore, modelPropertyMacro) {\n  // Resolve the schema (Handle nested schemas)\n  schema = Helpers.resolveSchema(schema);\n\n  if(typeof modelPropertyMacro !== 'function') {\n    modelPropertyMacro = function(prop){\n      return (prop || {}).default;\n    };\n  }\n\n  modelsToIgnore= modelsToIgnore || {};\n\n  var type = schema.type || 'object';\n  var format = schema.format;\n  var model;\n  var output;\n\n  if (!_.isUndefined(schema.example)) {\n    output = schema.example;\n  } else if (_.isUndefined(schema.items) && _.isArray(schema.enum)) {\n    output = schema.enum[0];\n  }\n\n  if (_.isUndefined(output)) {\n    if (schema.$ref) {\n      model = models[Helpers.simpleRef(schema.$ref)];\n\n      if (!_.isUndefined(model)) {\n        if (_.isUndefined(modelsToIgnore[model.name])) {\n          modelsToIgnore[model.name] = model;\n          output = schemaToJSON(model.definition, models, modelsToIgnore, modelPropertyMacro);\n          delete modelsToIgnore[model.name];\n        } else {\n          if (model.type === 'array') {\n            output = [];\n          } else {\n            output = {};\n          }\n        }\n      }\n    } else if (!_.isUndefined(schema.default)) {\n      output = schema.default;\n    } else if (type === 'string') {\n      if (format === 'date-time') {\n        output = new Date().toISOString();\n      } else if (format === 'date') {\n        output = new Date().toISOString().split('T')[0];\n      } else {\n        output = 'string';\n      }\n    } else if (type === 'integer') {\n      output = 0;\n    } else if (type === 'number') {\n      output = 0.0;\n    } else if (type === 'boolean') {\n      output = true;\n    } else if (type === 'object') {\n      output = {};\n\n      _.forEach(schema.properties, function (property, name) {\n        var cProperty = _.cloneDeep(property);\n\n        // Allow macro to set the default value\n        cProperty.default = modelPropertyMacro(property);\n\n        output[name] = schemaToJSON(cProperty, models, modelsToIgnore, modelPropertyMacro);\n      });\n    } else if (type === 'array') {\n      output = [];\n\n      if (_.isArray(schema.items)) {\n        _.forEach(schema.items, function (item) {\n          output.push(schemaToJSON(item, models, modelsToIgnore, modelPropertyMacro));\n        });\n      } else if (_.isPlainObject(schema.items)) {\n        output.push(schemaToJSON(schema.items, models, modelsToIgnore, modelPropertyMacro));\n      } else if (_.isUndefined(schema.items)) {\n        output.push({});\n      } else {\n        Helpers.log('Array type\\'s \\'items\\' property is not an array or an object, cannot process');\n      }\n    }\n  }\n\n  return output;\n}\n\nfunction schemaToHTML(name, schema, models, modelPropertyMacro) {\n\n  var strongOpen = '<span class=\"strong\">';\n  var strongClose = '</span>';\n\n  // Allow for ignoring the 'name' argument.... shifting the rest\n  if(_.isObject(arguments[0])) {\n    name = void 0;\n    schema = arguments[0];\n    models = arguments[1];\n    modelPropertyMacro = arguments[2];\n  }\n\n  models = models || {};\n\n  // Resolve the schema (Handle nested schemas)\n  schema = Helpers.resolveSchema(schema);\n\n  // Return for empty object\n  if(_.isEmpty(schema)) {\n    return strongOpen + 'Empty' + strongClose;\n  }\n\n  // Dereference $ref from 'models'\n  if(typeof schema.$ref === 'string') {\n    name = Helpers.simpleRef(schema.$ref);\n    schema = models[name];\n    if(typeof schema === 'undefined')\n    {\n      return strongOpen + name + ' is not defined!' + strongClose;\n    }\n  }\n\n  if(typeof name !== 'string') {\n    name = schema.title || 'Inline Model';\n  }\n\n  // If we are a Model object... adjust accordingly\n  if(schema.definition) {\n    schema = schema.definition;\n  }\n\n  if(typeof modelPropertyMacro !== 'function') {\n    modelPropertyMacro = function(prop){\n      return (prop || {}).default;\n    };\n  }\n\n  var references = {};\n  var seenModels = [];\n  var inlineModels = 0;\n\n\n\n  // Generate current HTML\n  var html = processModel(schema, name);\n\n  // Generate references HTML\n  while (_.keys(references).length > 0) {\n    /* jshint ignore:start */\n    _.forEach(references, function (schema, name) {\n      var seenModel = _.indexOf(seenModels, name) > -1;\n\n      delete references[name];\n\n      if (!seenModel) {\n        seenModels.push(name);\n\n        html += '<br />' + processModel(schema, name);\n      }\n    });\n    /* jshint ignore:end */\n  }\n\n  return html;\n\n  /////////////////////////////////\n\n  function addReference(schema, name, skipRef) {\n    var modelName = name;\n    var model;\n\n    if (schema.$ref) {\n      modelName = schema.title || Helpers.simpleRef(schema.$ref);\n      model = models[modelName];\n    } else if (_.isUndefined(name)) {\n      modelName = schema.title || 'Inline Model ' + (++inlineModels);\n      model = {definition: schema};\n    }\n\n    if (skipRef !== true) {\n      references[modelName] = _.isUndefined(model) ? {} : model.definition;\n    }\n\n    return modelName;\n  }\n\n  function primitiveToHTML(schema) {\n    var html = '<span class=\"propType\">';\n    var type = schema.type || 'object';\n\n    if (schema.$ref) {\n      html += addReference(schema, Helpers.simpleRef(schema.$ref));\n    } else if (type === 'object') {\n      if (!_.isUndefined(schema.properties)) {\n        html += addReference(schema);\n      } else {\n        html += 'object';\n      }\n    } else if (type === 'array') {\n      html += 'Array[';\n\n      if (_.isArray(schema.items)) {\n        html += _.map(schema.items, addReference).join(',');\n      } else if (_.isPlainObject(schema.items)) {\n        if (_.isUndefined(schema.items.$ref)) {\n          if (!_.isUndefined(schema.items.type) && _.indexOf(['array', 'object'], schema.items.type) === -1) {\n            html += schema.items.type;\n          } else {\n            html += addReference(schema.items);\n          }\n        } else {\n          html += addReference(schema.items, Helpers.simpleRef(schema.items.$ref));\n        }\n      } else {\n        Helpers.log('Array type\\'s \\'items\\' schema is not an array or an object, cannot process');\n        html += 'object';\n      }\n\n      html += ']';\n    } else {\n      html += schema.type;\n    }\n\n    html += '</span>';\n\n    return html;\n  }\n\n  function primitiveToOptionsHTML(schema, html) {\n    var options = '';\n    var type = schema.type || 'object';\n    var isArray = type === 'array';\n\n    if (isArray) {\n      if (_.isPlainObject(schema.items) && !_.isUndefined(schema.items.type)) {\n        type = schema.items.type;\n      } else {\n        type = 'object';\n      }\n    }\n\n    if (!_.isUndefined(schema.default)) {\n      options += optionHtml('Default', schema.default);\n    }\n\n    switch (type) {\n    case 'string':\n      if (schema.minLength) {\n        options += optionHtml('Min. Length', schema.minLength);\n      }\n\n      if (schema.maxLength) {\n        options += optionHtml('Max. Length', schema.maxLength);\n      }\n\n      if (schema.pattern) {\n        options += optionHtml('Reg. Exp.', schema.pattern);\n      }\n      break;\n    case 'integer':\n    case 'number':\n      if (schema.minimum) {\n        options += optionHtml('Min. Value', schema.minimum);\n      }\n\n      if (schema.exclusiveMinimum) {\n        options += optionHtml('Exclusive Min.', 'true');\n      }\n\n      if (schema.maximum) {\n        options += optionHtml('Max. Value', schema.maximum);\n      }\n\n      if (schema.exclusiveMaximum) {\n        options += optionHtml('Exclusive Max.', 'true');\n      }\n\n      if (schema.multipleOf) {\n        options += optionHtml('Multiple Of', schema.multipleOf);\n      }\n\n      break;\n    }\n\n    if (isArray) {\n      if (schema.minItems) {\n        options += optionHtml('Min. Items', schema.minItems);\n      }\n\n      if (schema.maxItems) {\n        options += optionHtml('Max. Items', schema.maxItems);\n      }\n\n      if (schema.uniqueItems) {\n        options += optionHtml('Unique Items', 'true');\n      }\n\n      if (schema.collectionFormat) {\n        options += optionHtml('Coll. Format', schema.collectionFormat);\n      }\n    }\n\n    if (_.isUndefined(schema.items)) {\n      if (_.isArray(schema.enum)) {\n        var enumString;\n\n        if (type === 'number' || type === 'integer') {\n          enumString = schema.enum.join(', ');\n        } else {\n          enumString = '\"' + schema.enum.join('\", \"') + '\"';\n        }\n\n        options += optionHtml('Enum', enumString);\n      }\n    }\n\n    if (options.length > 0) {\n      html = '<span class=\"propWrap\">' + html + '<table class=\"optionsWrapper\"><tr><th colspan=\"2\">' + type + '</th></tr>' + options + '</table></span>';\n    }\n\n    return html;\n  }\n\n  function processModel(schema, name) {\n    var type = schema.type || 'object';\n    var isArray = schema.type === 'array';\n    var html = strongOpen + name + ' ' + (isArray ? '[' : '{') + strongClose;\n\n    if (name) {\n      seenModels.push(name);\n    }\n\n    if (isArray) {\n      if (_.isArray(schema.items)) {\n        html += '<div>' + _.map(schema.items, function (item) {\n          var type = item.type || 'object';\n\n          if (_.isUndefined(item.$ref)) {\n            if (_.indexOf(['array', 'object'], type) > -1) {\n              if (type === 'object' && _.isUndefined(item.properties)) {\n                return 'object';\n              } else {\n                return addReference(item);\n              }\n            } else {\n              return primitiveToOptionsHTML(item, type);\n            }\n          } else {\n            return addReference(item, Helpers.simpleRef(item.$ref));\n          }\n        }).join(',</div><div>');\n      } else if (_.isPlainObject(schema.items)) {\n        if (_.isUndefined(schema.items.$ref)) {\n          if (_.indexOf(['array', 'object'], schema.items.type || 'object') > -1) {\n            if ((_.isUndefined(schema.items.type) || schema.items.type === 'object') && _.isUndefined(schema.items.properties)) {\n              html += '<div>object</div>';\n            } else {\n              html += '<div>' + addReference(schema.items) + '</div>';\n            }\n          } else {\n            html += '<div>' + primitiveToOptionsHTML(schema.items, schema.items.type) + '</div>';\n          }\n        } else {\n          html += '<div>' + addReference(schema.items, Helpers.simpleRef(schema.items.$ref)) + '</div>';\n        }\n      } else {\n        Helpers.log('Array type\\'s \\'items\\' property is not an array or an object, cannot process');\n        html += '<div>object</div>';\n      }\n    } else {\n      if (schema.$ref) {\n        html += '<div>' + addReference(schema, name) + '</div>';\n      } else if (type === 'object') {\n        if (_.isPlainObject(schema.properties)) {\n          var contents = _.map(schema.properties, function (property, name) {\n            var propertyIsRequired = (_.indexOf(schema.required, name) >= 0);\n            var cProperty = _.cloneDeep(property);\n\n            var requiredClass = propertyIsRequired ? 'required' : '';\n            var html = '<div' + (property.readOnly ? ' class=\"readOnly\"' : '') + '><span class=\"propName ' + requiredClass + '\">' + name + '</span> (';\n            var model;\n            var propDescription;\n\n            // Allow macro to set the default value\n            cProperty.default = modelPropertyMacro(cProperty);\n\n            // Resolve the schema (Handle nested schemas)\n            cProperty = Helpers.resolveSchema(cProperty);\n\n            propDescription = property.description || cProperty.description;\n\n            // We need to handle property references to primitives (Issue 339)\n            if (!_.isUndefined(cProperty.$ref)) {\n              model = models[Helpers.simpleRef(cProperty.$ref)];\n\n              if (!_.isUndefined(model) && _.indexOf([undefined, 'array', 'object'], model.definition.type) === -1) {\n                // Use referenced schema\n                cProperty = Helpers.resolveSchema(model.definition);\n              }\n            }\n\n            html += primitiveToHTML(cProperty);\n\n            if(!propertyIsRequired) {\n              html += ', <span class=\"propOptKey\">optional</span>';\n            }\n\n            if(property.readOnly) {\n                html += ', <span class=\"propReadOnly\">read only</span>';\n            }\n\n            html += ')';\n\n            if (!_.isUndefined(propDescription)) {\n              html += ': ' + '<span class=\"propDesc\">' + propDescription + '</span>';\n            }\n\n            if (cProperty.enum) {\n              html += ' = <span class=\"propVals\">[\\'' + cProperty.enum.join('\\', \\'') + '\\']</span>';\n            }\n\n            return primitiveToOptionsHTML(cProperty, html);\n          }).join(',</div>');\n        }\n\n        if (contents) {\n          html += contents + '</div>';\n        }\n      } else {\n        html += '<div>' + primitiveToOptionsHTML(schema, type) + '</div>';\n      }\n    }\n\n    return html + strongOpen + (isArray ? ']' : '}') + strongClose;\n  }\n}\n","'use strict';\n\nvar SwaggerHttp = require('./http');\nvar _ = {\n  isObject: require('lodash-compat/lang/isObject')\n};\n\nvar SwaggerSpecConverter = module.exports = function () {\n  this.errors = [];\n  this.warnings = [];\n  this.modelMap = {};\n};\n\nSwaggerSpecConverter.prototype.setDocumentationLocation = function (location) {\n  this.docLocation = location;\n};\n\n/**\n * converts a resource listing OR api declaration\n **/\nSwaggerSpecConverter.prototype.convert = function (obj, clientAuthorizations, opts, callback) {\n  // not a valid spec\n  if(!obj || !Array.isArray(obj.apis)) {\n    return this.finish(callback, null);\n  }\n  this.clientAuthorizations = clientAuthorizations;\n\n  // create a new swagger object to return\n  var swagger = { swagger: '2.0' };\n\n  swagger.originalVersion = obj.swaggerVersion;\n\n  // add the info\n  this.apiInfo(obj, swagger);\n\n  // add security definitions\n  this.securityDefinitions(obj, swagger);\n\n  // take basePath into account\n  if (obj.basePath) {\n    this.setDocumentationLocation(obj.basePath);\n  }\n\n  // see if this is a single-file swagger definition\n  var isSingleFileSwagger = false;\n  var i;\n  for(i = 0; i < obj.apis.length; i++) {\n    var api = obj.apis[i];\n    if(Array.isArray(api.operations)) {\n      isSingleFileSwagger = true;\n    }\n  }\n  if(isSingleFileSwagger) {\n    this.declaration(obj, swagger);\n    this.finish(callback, swagger);\n  }\n  else {\n    this.resourceListing(obj, swagger, opts, callback);\n  }\n};\n\nSwaggerSpecConverter.prototype.declaration = function(obj, swagger) {\n  var name, i, p, pos;\n  if(!obj.apis) {\n    return;\n  }\n\n  if (obj.basePath.indexOf('http://') === 0) {\n    p = obj.basePath.substring('http://'.length);\n    pos = p.indexOf('/');\n    if (pos > 0) {\n      swagger.host = p.substring(0, pos);\n      swagger.basePath = p.substring(pos);\n    }\n    else {\n      swagger.host = p;\n      swagger.basePath = '/';\n    }\n  } else if (obj.basePath.indexOf('https://') === 0) {\n    p = obj.basePath.substring('https://'.length);\n    pos = p.indexOf('/');\n    if (pos > 0) {\n      swagger.host = p.substring(0, pos);\n      swagger.basePath = p.substring(pos);\n    }\n    else {\n      swagger.host = p;\n      swagger.basePath = '/';\n    }\n  } else {\n    swagger.basePath = obj.basePath;\n  }\n\n  var resourceLevelAuth;\n  if(obj.authorizations) {\n    resourceLevelAuth = obj.authorizations;\n  }\n  if(obj.consumes) {\n    swagger.consumes = obj.consumes;\n  }\n  if(obj.produces) {\n    swagger.produces = obj.produces;\n  }\n\n  // build a mapping of id to name for 1.0 model resolutions\n  if(_.isObject(obj)) {\n    for(name in obj.models) {\n      var existingModel = obj.models[name];\n      var key = (existingModel.id || name);\n      this.modelMap[key] = name;\n    }\n  }\n\n  for(i = 0; i < obj.apis.length; i++) {\n    var api = obj.apis[i];\n    var path = api.path;\n    var operations = api.operations;\n    this.operations(path, obj.resourcePath, operations, resourceLevelAuth, swagger);\n  }\n\n  var models = obj.models || {};\n  this.models(models, swagger);\n};\n\nSwaggerSpecConverter.prototype.models = function(obj, swagger) {\n  if(!_.isObject(obj)) {\n    return;\n  }\n  var name;\n\n  swagger.definitions = swagger.definitions || {};\n  for(name in obj) {\n    var existingModel = obj[name];\n    var _enum = [];\n    var schema = { properties: {}};\n    var propertyName;\n    for(propertyName in existingModel.properties) {\n      var existingProperty = existingModel.properties[propertyName];\n      var property = {};\n      this.dataType(existingProperty, property);\n      if(existingProperty.description) {\n        property.description = existingProperty.description;\n      }\n      if(existingProperty['enum']) {\n        property['enum'] = existingProperty['enum'];\n      }\n      if(typeof existingProperty.required === 'boolean' && existingProperty.required === true) {\n        _enum.push(propertyName);\n      }\n      if(typeof existingProperty.required === 'string' && existingProperty.required === 'true') {\n        _enum.push(propertyName);\n      }\n      schema.properties[propertyName] = property;\n    }\n    if(_enum.length > 0) {\n      schema['enum'] = _enum;\n    }\n\n    schema.required = existingModel.required;\n    swagger.definitions[name] = schema;\n  }\n};\n\nSwaggerSpecConverter.prototype.extractTag = function(resourcePath) {\n  var pathString = resourcePath || 'default';\n  if(pathString.indexOf('http:') === 0 || pathString.indexOf('https:') === 0) {\n    pathString = pathString.split(['/']);\n    pathString = pathString[pathString.length -1].substring();\n  }\n  if(pathString.endsWith('.json')) {\n    pathString = pathString.substring(0, pathString.length - '.json'.length);\n  }\n  return pathString.replace('/','');\n};\n\nSwaggerSpecConverter.prototype.operations = function(path, resourcePath, obj, resourceLevelAuth, swagger) {\n  if(!Array.isArray(obj)) {\n    return;\n  }\n  var i;\n\n  if(!swagger.paths) {\n    swagger.paths = {};\n  }\n\n  var pathObj = swagger.paths[path] || {};\n  var tag = this.extractTag(resourcePath);\n  swagger.tags = swagger.tags || [];\n  var matched = false;\n  for(i = 0; i < swagger.tags.length; i++) {\n    var tagObject = swagger.tags[i];\n    if(tagObject.name === tag) {\n      matched = true;\n    }\n  }\n  if(!matched) {\n    swagger.tags.push({name: tag});\n  }\n\n  for(i = 0; i < obj.length; i++) {\n    var existingOperation = obj[i];\n    var method = (existingOperation.method || existingOperation.httpMethod).toLowerCase();\n    var operation = {tags: [tag]};\n    var existingAuthorizations = existingOperation.authorizations;\n\n    if(existingAuthorizations && Object.keys(existingAuthorizations).length === 0) {\n      existingAuthorizations = resourceLevelAuth;\n    }\n\n    if(typeof existingAuthorizations !== 'undefined') {\n      var scopesObject;\n      for(var key in existingAuthorizations) {\n        operation.security = operation.security || [];\n        var scopes = existingAuthorizations[key];\n        if(scopes) {\n          var securityScopes = [];\n          for(var j in scopes) {\n            securityScopes.push(scopes[j].scope);\n          }\n          scopesObject = {};\n          scopesObject[key] = securityScopes;\n          operation.security.push(scopesObject);\n        }\n        else {\n          scopesObject = {};\n          scopesObject[key] = [];\n          operation.security.push(scopesObject);\n        }\n      }\n    }\n\n    if(existingOperation.consumes) {\n      operation.consumes = existingOperation.consumes;\n    }\n    else if(swagger.consumes) {\n      operation.consumes = swagger.consumes;\n    }\n    if(existingOperation.produces) {\n      operation.produces = existingOperation.produces;\n    }\n    else if(swagger.produces) {\n      operation.produces = swagger.produces;\n    }\n    if(existingOperation.summary) {\n      operation.summary = existingOperation.summary;\n    }\n    if(existingOperation.notes) {\n      operation.description = existingOperation.notes;\n    }\n    if(existingOperation.nickname) {\n      operation.operationId = existingOperation.nickname;\n    }\n    if(existingOperation.deprecated) {\n      operation.deprecated = existingOperation.deprecated;\n    }\n\n    this.authorizations(existingAuthorizations, swagger);\n    this.parameters(operation, existingOperation.parameters, swagger);\n    this.responseMessages(operation, existingOperation, swagger);\n\n    pathObj[method] = operation;\n  }\n\n  swagger.paths[path] = pathObj;\n};\n\nSwaggerSpecConverter.prototype.responseMessages = function(operation, existingOperation) {\n  if(!_.isObject(existingOperation)) {\n    return;\n  }\n  // build default response from the operation (1.x)\n  var defaultResponse = {};\n  this.dataType(existingOperation, defaultResponse);\n  // TODO: look into the real problem of rendering responses in swagger-ui\n  // ....should reponseType have an implicit schema?\n  if(!defaultResponse.schema && defaultResponse.type) {\n    defaultResponse = {schema: defaultResponse};\n  }\n\n  operation.responses = operation.responses || {};\n\n  // grab from responseMessages (1.2)\n  var has200 = false;\n  if(Array.isArray(existingOperation.responseMessages)) {\n    var i;\n    var existingResponses = existingOperation.responseMessages;\n    for(i = 0; i < existingResponses.length; i++) {\n      var existingResponse = existingResponses[i];\n      var response = { description: existingResponse.message };\n      if(existingResponse.code === 200) {\n        has200 = true;\n      }\n      // Convert responseModel -> schema{$ref: responseModel}\n      if(existingResponse.responseModel) {\n        response.schema = {'$ref': '#/definitions/' + existingResponse.responseModel};\n      }\n      operation.responses['' + existingResponse.code] = response;\n    }\n  }\n\n  if(has200) {\n    operation.responses['default'] = defaultResponse;\n  }\n  else {\n    operation.responses['200'] = defaultResponse;\n  }\n};\n\nSwaggerSpecConverter.prototype.authorizations = function(obj) {\n  // TODO\n  if(!_.isObject(obj)) {\n    return;\n  }\n};\n\nSwaggerSpecConverter.prototype.parameters = function(operation, obj) {\n  if(!Array.isArray(obj)) {\n    return;\n  }\n  var i;\n  for(i = 0; i < obj.length; i++) {\n    var existingParameter = obj[i];\n    var parameter = {};\n    parameter.name = existingParameter.name;\n    parameter.description = existingParameter.description;\n    parameter.required = existingParameter.required;\n    parameter.in = existingParameter.paramType;\n\n    // per #168\n    if(parameter.in === 'body') {\n      parameter.name = 'body';\n    }\n    if(parameter.in === 'form') {\n      parameter.in = 'formData';\n    }\n\n    if(existingParameter.enum) {\n      parameter.enum = existingParameter.enum;\n    }\n\n    if(existingParameter.allowMultiple === true || existingParameter.allowMultiple === 'true') {\n      var innerType = {};\n      this.dataType(existingParameter, innerType);\n      parameter.type = 'array';\n      parameter.items = innerType;\n\n      if(existingParameter.allowableValues) {\n        var av = existingParameter.allowableValues;\n        if(av.valueType === 'LIST') {\n          parameter['enum'] = av.values;\n        }\n      }\n    }\n    else {\n      this.dataType(existingParameter, parameter);\n    }\n    if(typeof existingParameter.defaultValue !== 'undefined') {\n      parameter.default = existingParameter.defaultValue;\n    }\n\n    operation.parameters = operation.parameters || [];\n    operation.parameters.push(parameter);\n  }\n};\n\nSwaggerSpecConverter.prototype.dataType = function(source, target) {\n  if(!_.isObject(source)) {\n    return;\n  }\n\n  if(source.minimum) {\n    target.minimum = source.minimum;\n  }\n  if(source.maximum) {\n    target.maximum = source.maximum;\n  }\n  if (source.format) {\n    target.format = source.format;\n  }\n\n  // default can be 'false'\n  if(typeof source.defaultValue !== 'undefined') {\n    target.default = source.defaultValue;\n  }\n\n  var jsonSchemaType = this.toJsonSchema(source);\n  if(jsonSchemaType) {\n    target = target || {};\n    if(jsonSchemaType.type) {\n      target.type = jsonSchemaType.type;\n    }\n    if(jsonSchemaType.format) {\n      target.format = jsonSchemaType.format;\n    }\n    if(jsonSchemaType.$ref) {\n      target.schema = {$ref: jsonSchemaType.$ref};\n    }\n    if(jsonSchemaType.items) {\n      target.items = jsonSchemaType.items;\n    }\n  }\n};\n\nSwaggerSpecConverter.prototype.toJsonSchema = function(source) {\n  if(!source) {\n    return 'object';\n  }\n  var detectedType = (source.type || source.dataType || source.responseClass || '');\n  var lcType = detectedType.toLowerCase();\n  var format = (source.format || '').toLowerCase();\n\n  if(lcType.indexOf('list[') === 0) {\n    var innerType = detectedType.substring(5, detectedType.length - 1);\n    var jsonType = this.toJsonSchema({type: innerType});\n    return {type: 'array', items: jsonType};\n  } else if(lcType === 'int' || (lcType === 'integer' && format === 'int32')) {\n    {return {type: 'integer', format: 'int32'};}\n  } else if(lcType === 'long' || (lcType === 'integer' && format === 'int64')) {\n    {return {type: 'integer', format: 'int64'};}\n  } else if(lcType === 'integer') {\n    {return {type: 'integer', format: 'int64'};}\n  } else if(lcType === 'float' || (lcType === 'number' && format === 'float')) {\n    {return {type: 'number', format: 'float'};}\n  } else if(lcType === 'double' || (lcType === 'number' && format === 'double')) {\n    {return {type: 'number', format: 'double'};}\n  } else if((lcType === 'string' && format === 'date-time') || (lcType === 'date')) {\n    {return {type: 'string', format: 'date-time'};}\n  } else if(lcType === 'string') {\n    {return {type: 'string'};}\n  } else if(lcType === 'file') {\n    {return {type: 'file'};}\n  } else if(lcType === 'boolean') {\n    {return {type: 'boolean'};}\n  } else if(lcType === 'boolean') {\n    {return {type: 'boolean'};}\n  } else if(lcType === 'array' || lcType === 'list') {\n    if(source.items) {\n      var it = this.toJsonSchema(source.items);\n      return {type: 'array', items: it};\n    }\n    else {\n      return {type: 'array', items: {type: 'object'}};\n    }\n  } else if(source.$ref) {\n    return {$ref: this.modelMap[source.$ref] ? '#/definitions/' + this.modelMap[source.$ref] : source.$ref};\n  } else if(lcType === 'void' || lcType === '') {\n    {return {};}\n  } else if (this.modelMap[source.type]) {\n    // If this a model using `type` instead of `$ref`, that's fine.\n    return {$ref: '#/definitions/' + this.modelMap[source.type]};\n  } else {\n    // Unknown model type or 'object', pass it along.\n    return {type: source.type};\n  }\n};\n\nSwaggerSpecConverter.prototype.resourceListing = function(obj, swagger, opts, callback) {\n  var i;\n  var processedCount = 0;   // jshint ignore:line\n  var self = this;          // jshint ignore:line\n  var expectedCount = obj.apis.length;\n  var _swagger = swagger;   // jshint ignore:line\n  var _opts = {};\n\n  if(opts && opts.requestInterceptor){\n    _opts.requestInterceptor = opts.requestInterceptor;\n  }\n\n  if(opts && opts.responseInterceptor){\n    _opts.responseInterceptor = opts.responseInterceptor;\n  }\n\n  if(expectedCount === 0) {\n    this.finish(callback, swagger);\n  }\n\n  for(i = 0; i < expectedCount; i++) {\n    var api = obj.apis[i];\n    var path = api.path;\n    var absolutePath = this.getAbsolutePath(obj.swaggerVersion, this.docLocation, path);\n\n    if(api.description) {\n      swagger.tags = swagger.tags || [];\n      swagger.tags.push({\n        name : this.extractTag(api.path),\n        description : api.description || ''\n      });\n    }\n    var http = {\n      url: absolutePath,\n      headers: {accept: 'application/json'},\n      on: {},\n      method: 'get'\n    };\n    /* jshint ignore:start */\n    http.on.response = function(data) {\n      processedCount += 1;\n      var obj = data.obj;\n      if(obj) {\n        self.declaration(obj, _swagger);\n      }\n      if(processedCount === expectedCount) {\n        self.finish(callback, _swagger);\n      }\n    };\n    http.on.error = function(data) {\n      console.error(data);\n      processedCount += 1;\n      if(processedCount === expectedCount) {\n        self.finish(callback, _swagger);\n      }\n    };\n    /* jshint ignore:end */\n\n    if(this.clientAuthorizations && typeof this.clientAuthorizations.apply === 'function') {\n      this.clientAuthorizations.apply(http);\n    }\n\n    new SwaggerHttp().execute(http, _opts);\n  }\n};\n\nSwaggerSpecConverter.prototype.getAbsolutePath = function(version, docLocation, path)  {\n  if(version === '1.0') {\n    if(docLocation.endsWith('.json')) {\n      // get root path\n      var pos = docLocation.lastIndexOf('/');\n      if(pos > 0) {\n        docLocation = docLocation.substring(0, pos);\n      }\n    }\n  }\n\n  var location = docLocation;\n  if(path.indexOf('http://') === 0 || path.indexOf('https://') === 0) {\n    location = path;\n  }\n  else {\n    if(docLocation.endsWith('/')) {\n      location = docLocation.substring(0, docLocation.length - 1);\n    }\n    location += path;\n  }\n  location = location.replace('{format}', 'json');\n  return location;\n};\n\nSwaggerSpecConverter.prototype.securityDefinitions = function(obj, swagger) {\n  if(obj.authorizations) {\n    var name;\n    for(name in obj.authorizations) {\n      var isValid = false;\n      var securityDefinition = {};\n      var definition = obj.authorizations[name];\n      if(definition.type === 'apiKey') {\n        securityDefinition.type = 'apiKey';\n        securityDefinition.in = definition.passAs;\n        securityDefinition.name = definition.keyname || name;\n        isValid = true;\n      }\n      else if(definition.type === 'basicAuth') {\n        securityDefinition.type = 'basicAuth';\n        isValid = true;\n      }\n      else if(definition.type === 'oauth2') {\n        var existingScopes = definition.scopes || [];\n        var scopes = {};\n        var i;\n        for(i in existingScopes) {\n          var scope = existingScopes[i];\n          scopes[scope.scope] = scope.description;\n        }\n        securityDefinition.type = 'oauth2';\n        if(i > 0) {\n          securityDefinition.scopes = scopes;\n        }\n        if(definition.grantTypes) {\n          if(definition.grantTypes.implicit) {\n            var implicit = definition.grantTypes.implicit;\n            securityDefinition.flow = 'implicit';\n            securityDefinition.authorizationUrl = implicit.loginEndpoint;\n            isValid = true;\n          }\n          /* jshint ignore:start */\n          if(definition.grantTypes['authorization_code']) {\n            if(!securityDefinition.flow) {\n              // cannot set if flow is already defined\n              var authCode = definition.grantTypes['authorization_code'];\n              securityDefinition.flow = 'accessCode';\n              securityDefinition.authorizationUrl = authCode.tokenRequestEndpoint.url;\n              securityDefinition.tokenUrl = authCode.tokenEndpoint.url;\n              isValid = true;\n            }\n          }\n          /* jshint ignore:end */\n        }\n      }\n      if(isValid) {\n        swagger.securityDefinitions = swagger.securityDefinitions || {};\n        swagger.securityDefinitions[name] = securityDefinition;\n      }\n    }\n  }\n};\n\nSwaggerSpecConverter.prototype.apiInfo = function(obj, swagger) {\n  // info section\n  if(obj.info) {\n    var info = obj.info;\n    swagger.info = {};\n\n    if(info.contact) {\n      swagger.info.contact = {};\n      swagger.info.contact.email = info.contact;\n    }\n    if(info.description) {\n      swagger.info.description = info.description;\n    }\n    if(info.title) {\n      swagger.info.title = info.title;\n    }\n    if(info.termsOfServiceUrl) {\n      swagger.info.termsOfService = info.termsOfServiceUrl;\n    }\n    if(info.license || info.licenseUrl) {\n      swagger.license = {};\n      if(info.license) {\n        swagger.license.name = info.license;\n      }\n      if(info.licenseUrl) {\n        swagger.license.url = info.licenseUrl;\n      }\n    }\n  }\n  else {\n    this.warnings.push('missing info section');\n  }\n};\n\nSwaggerSpecConverter.prototype.finish = function (callback, obj) {\n  callback(obj);\n};\n","'use strict';\n\nvar _ = {\n  isPlainObject: require('lodash-compat/lang/isPlainObject'),\n  isString: require('lodash-compat/lang/isString'),\n};\n\nvar SchemaMarkup = require('../schema-markup.js');\nvar jsyaml = require('js-yaml');\n\nvar Model = module.exports = function (name, definition, models, modelPropertyMacro) {\n  this.definition = definition || {};\n  this.isArray = definition.type === 'array';\n  this.models = models || {};\n  this.name = definition.title || name || 'Inline Model';\n  this.modelPropertyMacro = modelPropertyMacro || function (property) {\n    return property.default;\n  };\n\n  return this;\n};\n\nModel.prototype.createJSONSample = Model.prototype.getSampleValue = function (modelsToIgnore) {\n  modelsToIgnore = modelsToIgnore || {};\n\n  modelsToIgnore[this.name] = this;\n\n  // Response support\n  if (this.examples && _.isPlainObject(this.examples) && this.examples['application/json']) {\n    this.definition.example = this.examples['application/json'];\n\n    if (_.isString(this.definition.example)) {\n      this.definition.example = jsyaml.safeLoad(this.definition.example);\n    }\n  } else if (!this.definition.example) {\n    this.definition.example = this.examples;\n  }\n\n  return SchemaMarkup.schemaToJSON(this.definition, this.models, modelsToIgnore, this.modelPropertyMacro);\n};\n\nModel.prototype.getMockSignature = function () {\n  return SchemaMarkup.schemaToHTML(this.name, this.definition, this.models, this.modelPropertyMacro);\n};\n","'use strict';\n\nvar _ = {\n  cloneDeep: require('lodash-compat/lang/cloneDeep'),\n  isUndefined: require('lodash-compat/lang/isUndefined'),\n  isEmpty: require('lodash-compat/lang/isEmpty'),\n  isObject: require('lodash-compat/lang/isObject')\n};\nvar helpers = require('../helpers');\nvar Model = require('./model');\nvar SwaggerHttp = require('../http');\nvar Q = require('q');\n\nvar Operation = module.exports = function (parent, scheme, operationId, httpMethod, path, args, definitions, models, clientAuthorizations) {\n  var errors = [];\n\n  parent = parent || {};\n  args = args || {};\n\n  if(parent && parent.options) {\n    this.client = parent.options.client || null;\n    this.requestInterceptor = parent.options.requestInterceptor || null;\n    this.responseInterceptor = parent.options.responseInterceptor || null;\n  }\n  this.authorizations = args.security;\n  this.basePath = parent.basePath || '/';\n  this.clientAuthorizations = clientAuthorizations;\n  this.consumes = args.consumes || parent.consumes || ['application/json'];\n  this.produces = args.produces || parent.produces || ['application/json'];\n  this.deprecated = args.deprecated;\n  this.description = args.description;\n  this.host = parent.host || 'localhost';\n  this.method = (httpMethod || errors.push('Operation ' + operationId + ' is missing method.'));\n  this.models = models || {};\n  this.nickname = (operationId || errors.push('Operations must have a nickname.'));\n  this.operation = args;\n  this.operations = {};\n  this.parameters = args !== null ? (args.parameters || []) : {};\n  this.parent = parent;\n  this.path = (path || errors.push('Operation ' + this.nickname + ' is missing path.'));\n  this.responses = (args.responses || {});\n  this.scheme = scheme || parent.scheme || 'http';\n  this.schemes = args.schemes || parent.schemes;\n  this.security = args.security;\n  this.summary = args.summary || '';\n  this.type = null;\n  this.useJQuery = parent.useJQuery;\n  this.enableCookies = parent.enableCookies;\n  this.parameterMacro = parent.parameterMacro || function (operation, parameter) {\n    return parameter.default;\n  };\n\n  this.inlineModels = [];\n\n  if (typeof this.deprecated === 'string') {\n    switch(this.deprecated.toLowerCase()) {\n      case 'true': case 'yes': case '1': {\n        this.deprecated = true;\n        break;\n      }\n\n      case 'false': case 'no': case '0': case null: {\n        this.deprecated = false;\n        break;\n      }\n\n      default: this.deprecated = Boolean(this.deprecated);\n    }\n  }\n\n  var i, model;\n\n  if (definitions) {\n    // add to global models\n    var key;\n\n    for (key in definitions) {\n      model = new Model(key, definitions[key], this.models, parent.modelPropertyMacro);\n\n      if (model) {\n        this.models[key] = model;\n      }\n    }\n  }\n  else {\n    definitions = {};\n  }\n\n  for (i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n\n    // Allow macro to set the default value\n    param.default = this.parameterMacro(this, param);\n\n    if (param.type === 'array') {\n      param.isList = true;\n      param.allowMultiple = true;\n      // the enum can be defined at the items level\n      //if (param.items && param.items.enum) {\n      //  param['enum'] = param.items.enum;\n      //}\n    }\n\n    var innerType = this.getType(param);\n\n    if (innerType && innerType.toString().toLowerCase() === 'boolean') {\n      param.allowableValues = {};\n      param.isList = true;\n      param['enum'] = [true, false]; // use actual primitives\n    }\n\n    if(typeof param['x-example'] !== 'undefined') {\n      var d = param['x-example'];\n      param.default = d;\n    }\n    if(param['x-examples']) {\n      var d = param['x-examples'].default;\n      if(typeof d !== 'undefined') {\n        param.default = d;\n      }\n    }\n\n    if (typeof param['enum'] !== 'undefined') {\n      var id;\n\n      param.allowableValues = {};\n      param.allowableValues.values = [];\n      param.allowableValues.descriptiveValues = [];\n\n      for (id = 0; id < param['enum'].length; id++) {\n        var value = param['enum'][id];\n        var isDefault = (value === param.default || value+'' === param.default);\n\n        param.allowableValues.values.push(value);\n        // Always have string for descriptive values....\n        param.allowableValues.descriptiveValues.push({value : value+'', isDefault: isDefault});\n      }\n    }\n\n    if (param.type === 'array') {\n      innerType = [innerType];\n\n      if (typeof param.allowableValues === 'undefined') {\n        // can't show as a list if no values to select from\n        delete param.isList;\n        delete param.allowMultiple;\n      }\n    }\n\n    param.signature = this.getModelSignature(innerType, this.models).toString();\n    param.sampleJSON = this.getModelSampleJSON(innerType, this.models);\n    param.responseClassSignature = param.signature;\n  }\n\n  var defaultResponseCode, response, responses = this.responses;\n\n  if (responses['200']) {\n    response = responses['200'];\n    defaultResponseCode = '200';\n  } else if (responses['201']) {\n    response = responses['201'];\n    defaultResponseCode = '201';\n  } else if (responses['202']) {\n    response = responses['202'];\n    defaultResponseCode = '202';\n  } else if (responses['203']) {\n    response = responses['203'];\n    defaultResponseCode = '203';\n  } else if (responses['204']) {\n    response = responses['204'];\n    defaultResponseCode = '204';\n  } else if (responses['205']) {\n    response = responses['205'];\n    defaultResponseCode = '205';\n  } else if (responses['206']) {\n    response = responses['206'];\n    defaultResponseCode = '206';\n  } else if (responses['default']) {\n    response = responses['default'];\n    defaultResponseCode = 'default';\n  }\n\n  if (response && response.schema) {\n    var resolvedModel = this.resolveModel(response.schema, definitions);\n    var successResponse;\n\n    delete responses[defaultResponseCode];\n\n    if (resolvedModel) {\n      this.successResponse = {};\n      successResponse = this.successResponse[defaultResponseCode] = resolvedModel;\n    } else if (!response.schema.type || response.schema.type === 'object' || response.schema.type === 'array') {\n      // Inline model\n      this.successResponse = {};\n      successResponse = this.successResponse[defaultResponseCode] = new Model(undefined, response.schema || {}, this.models, parent.modelPropertyMacro);\n    } else {\n      // Primitive\n      this.successResponse = {};\n      successResponse = this.successResponse[defaultResponseCode] = response.schema;\n    }\n\n    if (successResponse) {\n      // Attach response properties\n      if (response.description) {\n        successResponse.description = response.description;\n      }\n\n      if (response.examples) {\n        successResponse.examples = response.examples;\n      }\n\n      if (response.headers) {\n        successResponse.headers = response.headers;\n      }\n    }\n\n    this.type = response;\n  }\n\n  if (errors.length > 0) {\n    if (this.resource && this.resource.api && this.resource.api.fail) {\n      this.resource.api.fail(errors);\n    }\n  }\n\n  return this;\n};\n\nOperation.prototype.isDefaultArrayItemValue = function(value, param) {\n  if (param.default && Array.isArray(param.default)) {\n    return param.default.indexOf(value) !== -1;\n  }\n  return value === param.default;\n};\n\nOperation.prototype.getType = function (param) {\n  var type = param.type;\n  var format = param.format;\n  var isArray = false;\n  var str;\n\n  if (type === 'integer' && format === 'int32') {\n    str = 'integer';\n  } else if (type === 'integer' && format === 'int64') {\n    str = 'long';\n  } else if (type === 'integer') {\n    str = 'integer';\n  } else if (type === 'string') {\n    if (format === 'date-time') {\n      str = 'date-time';\n    } else if (format === 'date') {\n      str = 'date';\n    } else {\n      str = 'string';\n    }\n  } else if (type === 'number' && format === 'float') {\n    str = 'float';\n  } else if (type === 'number' && format === 'double') {\n    str = 'double';\n  } else if (type === 'number') {\n    str = 'double';\n  } else if (type === 'boolean') {\n    str = 'boolean';\n  } else if (type === 'array') {\n    isArray = true;\n\n    if (param.items) {\n      str = this.getType(param.items);\n    }\n  } else if (type === 'file') {\n    str = 'file';\n  }\n\n  if (param.$ref) {\n    str = helpers.simpleRef(param.$ref);\n  }\n\n  var schema = param.schema;\n\n  if (schema) {\n    var ref = schema.$ref;\n\n    if (ref) {\n      ref = helpers.simpleRef(ref);\n\n      if (isArray) {\n        return [ ref ];\n      } else {\n        return ref;\n      }\n    } else {\n      // If inline schema, we add it our interal hash -> which gives us it's ID (int)\n      if(schema.type === 'object') {\n        return this.addInlineModel(schema);\n      }\n      return this.getType(schema);\n    }\n  }\n  if (isArray) {\n    return [ str ];\n  } else {\n    return str;\n  }\n};\n\n/**\n * adds an inline schema (model) to a hash, where we can ref it later\n * @param {object} schema a schema\n * @return {number} the ID of the schema being added, or null\n **/\nOperation.prototype.addInlineModel = function (schema) {\n  var len = this.inlineModels.length;\n  var model = this.resolveModel(schema, {});\n  if(model) {\n    this.inlineModels.push(model);\n    return 'Inline Model '+len; // return string ref of the inline model (used with #getInlineModel)\n  }\n  return null; // report errors?\n};\n\n/**\n * gets the internal ref to an inline model\n * @param {string} inline_str a string reference to an inline model\n * @return {Model} the model being referenced. Or null\n **/\nOperation.prototype.getInlineModel = function(inlineStr) {\n  if(/^Inline Model \\d+$/.test(inlineStr)) {\n    var id = parseInt(inlineStr.substr('Inline Model'.length).trim(),10); //\n    var model = this.inlineModels[id];\n    return model;\n  }\n  // I'm returning null here, should I rather throw an error?\n  return null;\n};\n\nOperation.prototype.resolveModel = function (schema, definitions) {\n  if (typeof schema.$ref !== 'undefined') {\n    var ref = schema.$ref;\n\n    if (ref.indexOf('#/definitions/') === 0) {\n      ref = ref.substring('#/definitions/'.length);\n    }\n\n    if (definitions[ref]) {\n      return new Model(ref, definitions[ref], this.models, this.parent.modelPropertyMacro);\n    }\n  // schema must at least be an object to get resolved to an inline Model\n  } else if (schema && typeof schema === 'object' &&\n            (schema.type === 'object' || _.isUndefined(schema.type))) {\n    return new Model(undefined, schema, this.models, this.parent.modelPropertyMacro);\n  }\n\n  return null;\n};\n\nOperation.prototype.help = function (dontPrint) {\n  var out = this.nickname + ': ' + this.summary + '\\n';\n\n  for (var i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n    var typeInfo = param.signature;\n\n    out += '\\n  * ' + param.name + ' (' + typeInfo + '): ' + param.description;\n  }\n\n  if (typeof dontPrint === 'undefined') {\n    helpers.log(out);\n  }\n\n  return out;\n};\n\nOperation.prototype.getModelSignature = function (type, definitions) {\n  var isPrimitive, listType;\n\n  if (type instanceof Array) {\n    listType = true;\n    type = type[0];\n  }\n\n  // Convert undefined to string of 'undefined'\n  if (typeof type === 'undefined') {\n    type = 'undefined';\n    isPrimitive = true;\n\n  } else if (definitions[type]){\n    // a model def exists?\n    type = definitions[type]; /* Model */\n    isPrimitive = false;\n\n  } else if (this.getInlineModel(type)) {\n    type = this.getInlineModel(type); /* Model */\n    isPrimitive = false;\n\n  } else {\n    // We default to primitive\n    isPrimitive = true;\n  }\n\n  if (isPrimitive) {\n    if (listType) {\n      return 'Array[' + type + ']';\n    } else {\n      return type.toString();\n    }\n  } else {\n    if (listType) {\n      return 'Array[' + type.getMockSignature() + ']';\n    } else {\n      return type.getMockSignature();\n    }\n  }\n};\n\nOperation.prototype.supportHeaderParams = function () {\n  return true;\n};\n\nOperation.prototype.supportedSubmitMethods = function () {\n  return this.parent.supportedSubmitMethods;\n};\n\nOperation.prototype.getHeaderParams = function (args) {\n  var headers = this.setContentTypes(args, {});\n\n  for (var i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n\n    if (typeof args[param.name] !== 'undefined') {\n      if (param.in === 'header') {\n        var value = args[param.name];\n\n        if (Array.isArray(value)) {\n          value = value.toString();\n        }\n\n        headers[param.name] = value;\n      }\n    }\n  }\n\n  return headers;\n};\n\nOperation.prototype.urlify = function (args) {\n  var formParams = {};\n  var requestUrl = this.path;\n  var querystring = ''; // grab params from the args, build the querystring along the way\n\n  for (var i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n\n    if (typeof args[param.name] !== 'undefined') {\n      if (param.in === 'path') {\n        var reg = new RegExp('\\{' + param.name + '\\}', 'gi');\n        var value = args[param.name];\n\n        if (Array.isArray(value)) {\n          value = this.encodePathCollection(param.collectionFormat, param.name, value);\n        } else {\n          value = this.encodePathParam(value);\n        }\n\n        requestUrl = requestUrl.replace(reg, value);\n      } else if (param.in === 'query' && typeof args[param.name] !== 'undefined') {\n        if (querystring === '') {\n          querystring += '?';\n        } else {\n          querystring += '&';\n        }\n\n        if (typeof param.collectionFormat !== 'undefined') {\n          var qp = args[param.name];\n\n          if (Array.isArray(qp)) {\n            querystring += this.encodeQueryCollection(param.collectionFormat, param.name, qp);\n          } else {\n            querystring += this.encodeQueryParam(param.name) + '=' + this.encodeQueryParam(args[param.name]);\n          }\n        } else {\n          querystring += this.encodeQueryParam(param.name) + '=' + this.encodeQueryParam(args[param.name]);\n        }\n      } else if (param.in === 'formData') {\n        formParams[param.name] = args[param.name];\n      }\n    }\n  }\n  var url = this.scheme + '://' + this.host;\n\n  if (this.basePath !== '/') {\n    url += this.basePath;\n  }\n  return url + requestUrl + querystring;\n};\n\nOperation.prototype.getMissingParams = function (args) {\n  var missingParams = []; // check required params, track the ones that are missing\n  var i;\n\n  for (i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n\n    if (param.required === true) {\n      if (typeof args[param.name] === 'undefined') {\n        missingParams = param.name;\n      }\n    }\n  }\n\n  return missingParams;\n};\n\nOperation.prototype.getBody = function (headers, args, opts) {\n  var formParams = {}, hasFormParams, body, key, value, hasBody = false;\n\n  // look at each param and put form params in an object\n  for (var i = 0; i < this.parameters.length; i++) {\n    var param = this.parameters[i];\n    if (typeof args[param.name] !== 'undefined') {\n      if (param.in === 'body') {\n        body = args[param.name];\n      } else if (param.in === 'formData') {\n        formParams[param.name] = args[param.name];\n        hasFormParams = true;\n      }\n    }\n    else {\n      if(param.in === 'body') {\n        hasBody = true;\n      }\n    }\n  }\n\n  // if body is null and hasBody is true, AND a JSON body is requested, send empty {}\n  if(hasBody && typeof body === 'undefined') {\n    var contentType = headers['Content-Type'];\n    if(contentType && contentType.indexOf('application/json') === 0) {\n      body = '{}';\n    }\n  }\n\n  var isMultiPart = false;\n  if(headers['Content-Type'] && headers['Content-Type'].indexOf('multipart/form-data') >= 0) {\n    isMultiPart = true;\n  }\n\n  // handle form params\n  if (hasFormParams && !isMultiPart) {\n    var encoded = '';\n\n    for (key in formParams) {\n      value = formParams[key];\n\n      if (typeof value !== 'undefined') {\n        if (encoded !== '') {\n          encoded += '&';\n        }\n\n        encoded += encodeURIComponent(key) + '=' + encodeURIComponent(value);\n      }\n    }\n\n    body = encoded;\n  } else if (isMultiPart) {\n    if (opts.useJQuery) {\n      var bodyParam = new FormData();\n\n      bodyParam.type = 'formData';\n\n      for (key in formParams) {\n        value = args[key];\n\n        if (typeof value !== 'undefined') {\n          // required for jquery file upload\n          if (value.type === 'file' && value.value) {\n            delete headers['Content-Type'];\n\n            bodyParam.append(key, value.value);\n          } else {\n            bodyParam.append(key, value);\n          }\n        }\n      }\n\n      body = bodyParam;\n    }\n  }\n\n  return body;\n};\n\n/**\n * gets sample response for a single operation\n **/\nOperation.prototype.getModelSampleJSON = function (type, models) {\n  var listType, sampleJson, innerType;\n  models = models || {};\n\n  listType = (type instanceof Array);\n  innerType = listType ? type[0] : type;\n\n  if(models[innerType]) {\n    sampleJson = models[innerType].createJSONSample();\n  } else if (this.getInlineModel(innerType)){\n    sampleJson = this.getInlineModel(innerType).createJSONSample(); // may return null, if type isn't correct\n  }\n\n\n  if (sampleJson) {\n    sampleJson = listType ? [sampleJson] : sampleJson;\n\n    if (typeof sampleJson === 'string') {\n      return sampleJson;\n    } else if (_.isObject(sampleJson)) {\n      var t = sampleJson;\n\n      if (sampleJson instanceof Array && sampleJson.length > 0) {\n        t = sampleJson[0];\n      }\n\n      if (t.nodeName && typeof t === 'Node') {\n        var xmlString = new XMLSerializer().serializeToString(t);\n\n        return this.formatXml(xmlString);\n      } else {\n        return JSON.stringify(sampleJson, null, 2);\n      }\n    } else {\n      return sampleJson;\n    }\n  }\n};\n\n/**\n * legacy binding\n **/\nOperation.prototype.do = function (args, opts, callback, error, parent) {\n  return this.execute(args, opts, callback, error, parent);\n};\n\n/**\n * executes an operation\n **/\nOperation.prototype.execute = function (arg1, arg2, arg3, arg4, parent) {\n  var args = arg1 || {};\n  var opts = {}, success, error, deferred;\n\n  if (_.isObject(arg2)) {\n    opts = arg2;\n    success = arg3;\n    error = arg4;\n  }\n\n  if(this.client) {\n    opts.client = this.client;\n  }\n\n  // add the request interceptor from parent, if none sent from client\n  if(!opts.requestInterceptor && this.requestInterceptor ) {\n    opts.requestInterceptor = this.requestInterceptor ;\n  }\n\n  if(!opts.responseInterceptor && this.responseInterceptor) {\n    opts.responseInterceptor = this.responseInterceptor;\n  }\n\n  if (typeof arg2 === 'function') {\n    success = arg2;\n    error = arg3;\n  }\n\n  if (this.parent.usePromise) {\n    deferred = Q.defer();\n  } else {\n    success = (success || this.parent.defaultSuccessCallback || helpers.log);\n    error = (error || this.parent.defaultErrorCallback || helpers.log);\n  }\n\n\n  if (typeof opts.useJQuery === 'undefined') {\n    opts.useJQuery = this.useJQuery;\n  }\n\n  if (typeof opts.enableCookies === 'undefined') {\n    opts.enableCookies = this.enableCookies;\n  }\n\n  var missingParams = this.getMissingParams(args);\n\n  if (missingParams.length > 0) {\n    var message = 'missing required params: ' + missingParams;\n\n    helpers.fail(message);\n\n    if (this.parent.usePromise) {\n      deferred.reject(message);\n      return deferred.promise;\n    } else {\n      error(message, parent);\n      return {};\n    }\n  }\n\n  var allHeaders = this.getHeaderParams(args);\n  var contentTypeHeaders = this.setContentTypes(args, opts);\n  var headers = {}, attrname;\n\n  for (attrname in allHeaders) { headers[attrname] = allHeaders[attrname]; }\n  for (attrname in contentTypeHeaders) { headers[attrname] = contentTypeHeaders[attrname]; }\n\n  var body = this.getBody(contentTypeHeaders, args, opts);\n  var url = this.urlify(args);\n\n  if(url.indexOf('.{format}') > 0) {\n    if(headers) {\n      var format = headers.Accept || headers.accept;\n      if(format && format.indexOf('json') > 0) {\n        url = url.replace('.{format}', '.json');\n      }\n      else if(format && format.indexOf('xml') > 0) {\n        url = url.replace('.{format}', '.xml');\n      }\n    }\n  }\n\n  var obj = {\n    url: url,\n    method: this.method.toUpperCase(),\n    body: body,\n    enableCookies: opts.enableCookies,\n    useJQuery: opts.useJQuery,\n    deferred: deferred,\n    headers: headers,\n    on: {\n      response: function (response) {\n        if (deferred) {\n          deferred.resolve(response);\n          return deferred.promise;\n        } else {\n          return success(response, parent);\n        }\n      },\n      error: function (response) {\n        if (deferred) {\n          deferred.reject(response);\n          return deferred.promise;\n        } else {\n          return error(response, parent);\n        }\n      }\n    }\n  };\n\n  this.clientAuthorizations.apply(obj, this.operation.security);\n  if (opts.mock === true) {\n    return obj;\n  } else {\n    return new SwaggerHttp().execute(obj, opts);\n  }\n};\n\nfunction itemByPriority(col, itemPriority) {\n\n  // No priorities? return first...\n  if(_.isEmpty(itemPriority)) {\n    return col[0];\n  }\n\n  for (var i = 0, len = itemPriority.length; i < len; i++) {\n    if(col.indexOf(itemPriority[i]) > -1) {\n      return itemPriority[i];\n    }\n  }\n\n  // Otherwise return first\n  return col[0];\n}\n\nOperation.prototype.setContentTypes = function (args, opts) {\n  // default type\n  var allDefinedParams = this.parameters;\n  var body;\n  var consumes = args.parameterContentType || itemByPriority(this.consumes, ['application/json', 'application/yaml']);\n  var accepts = opts.responseContentType || itemByPriority(this.produces, ['application/json', 'application/yaml']);\n  var definedFileParams = [];\n  var definedFormParams = [];\n  var headers = {};\n  var i;\n\n  // get params from the operation and set them in definedFileParams, definedFormParams, headers\n  for (i = 0; i < allDefinedParams.length; i++) {\n    var param = allDefinedParams[i];\n\n    if (param.in === 'formData') {\n      if (param.type === 'file') {\n        definedFileParams.push(param);\n      } else {\n        definedFormParams.push(param);\n      }\n    } else if (param.in === 'header' && opts) {\n      var key = param.name;\n      var headerValue = opts[param.name];\n\n      if (typeof opts[param.name] !== 'undefined') {\n        headers[key] = headerValue;\n      }\n    } else if (param.in === 'body' && typeof args[param.name] !== 'undefined') {\n      body = args[param.name];\n    }\n  }\n\n  // if there's a body, need to set the consumes header via requestContentType\n  if (this.method === 'post' || this.method === 'put' || this.method === 'patch' ||\n      ((this.method === 'delete' || this.method === 'get') && body) ) {\n    if (opts.requestContentType) {\n      consumes = opts.requestContentType;\n    }\n    // if any form params, content type must be set\n    if (definedFormParams.length > 0) {\n      if (opts.requestContentType) {             // override if set\n        consumes = opts.requestContentType;\n      } else if (definedFileParams.length > 0) { // if a file, must be multipart/form-data\n        consumes = 'multipart/form-data';\n      } else {                                   // default to x-www-from-urlencoded\n        consumes = 'application/x-www-form-urlencoded';\n      }\n    }\n  }\n  else {\n    consumes = null;\n  }\n\n  if (consumes && this.consumes) {\n    if (this.consumes.indexOf(consumes) === -1) {\n      helpers.log('server doesn\\'t consume ' + consumes + ', try ' + JSON.stringify(this.consumes));\n    }\n  }\n\n  if (!this.matchesAccept(accepts)) {\n    helpers.log('server can\\'t produce ' + accepts);\n  }\n\n  if ((consumes && body !== '') || (consumes === 'application/x-www-form-urlencoded')) {\n    headers['Content-Type'] = consumes;\n  }\n\n  if (accepts) {\n    headers.Accept = accepts;\n  }\n\n  return headers;\n};\n\n/**\n * Returns true if the request accepts header matches anything in this.produces.\n *  If this.produces contains * / *, ignore the accept header.\n * @param {string=} accepts The client request accept header.\n * @return {boolean}\n */\nOperation.prototype.matchesAccept = function(accepts) {\n  // no accepts or produces, no problem!\n  if (!accepts || !this.produces) {\n    return true;\n  }\n  return this.produces.indexOf(accepts) !== -1 || this.produces.indexOf('*/*') !== -1;\n};\n\nOperation.prototype.asCurl = function (args1, args2) {\n  var opts = {mock: true};\n  if (typeof args2 === 'object') {\n    for (var argKey in args2) {\n      opts[argKey] = args2[argKey];\n    }\n  }\n  var obj = this.execute(args1, opts);\n\n  this.clientAuthorizations.apply(obj, this.operation.security);\n\n  var results = [];\n\n  results.push('-X ' + this.method.toUpperCase());\n\n  if (typeof obj.headers !== 'undefined') {\n    var key;\n\n    for (key in obj.headers) {\n      var value = obj.headers[key];\n      if(typeof value === 'string'){\n        value = value.replace(/\\'/g, '\\\\u0027');\n      }\n      results.push('--header \\'' + key + ': ' + value + '\\'');\n    }\n  }\n\n  if (obj.body) {\n    var body;\n\n    if (_.isObject(obj.body)) {\n      body = JSON.stringify(obj.body);\n    } else {\n      body = obj.body;\n    }\n\n    results.push('-d \\'' + body.replace(/\\'/g, '\\\\u0027') + '\\'');\n  }\n\n  return 'curl ' + (results.join(' ')) + ' \\'' + obj.url + '\\'';\n};\n\nOperation.prototype.encodePathCollection = function (type, name, value) {\n  var encoded = '';\n  var i;\n  var separator = '';\n\n  if (type === 'ssv') {\n    separator = '%20';\n  } else if (type === 'tsv') {\n    separator = '\\\\t';\n  } else if (type === 'pipes') {\n    separator = '|';\n  } else {\n    separator = ',';\n  }\n\n  for (i = 0; i < value.length; i++) {\n    if (i === 0) {\n      encoded = this.encodeQueryParam(value[i]);\n    } else {\n      encoded += separator + this.encodeQueryParam(value[i]);\n    }\n  }\n\n  return encoded;\n};\n\nOperation.prototype.encodeQueryCollection = function (type, name, value) {\n  var encoded = '';\n  var i;\n\n  if (type === 'default' || type === 'multi') {\n    for (i = 0; i < value.length; i++) {\n      if (i > 0) {encoded += '&';}\n\n      encoded += this.encodeQueryParam(name) + '=' + this.encodeQueryParam(value[i]);\n    }\n  } else {\n    var separator = '';\n\n    if (type === 'csv') {\n      separator = ',';\n    } else if (type === 'ssv') {\n      separator = '%20';\n    } else if (type === 'tsv') {\n      separator = '\\\\t';\n    } else if (type === 'pipes') {\n      separator = '|';\n    } else if (type === 'brackets') {\n      for (i = 0; i < value.length; i++) {\n        if (i !== 0) {\n          encoded += '&';\n        }\n\n        encoded += this.encodeQueryParam(name) + '[]=' + this.encodeQueryParam(value[i]);\n      }\n    }\n\n    if (separator !== '') {\n      for (i = 0; i < value.length; i++) {\n        if (i === 0) {\n          encoded = this.encodeQueryParam(name) + '=' + this.encodeQueryParam(value[i]);\n        } else {\n          encoded += separator + this.encodeQueryParam(value[i]);\n        }\n      }\n    }\n  }\n\n  return encoded;\n};\n\nOperation.prototype.encodeQueryParam = function (arg) {\n  return encodeURIComponent(arg);\n};\n\n/**\n * TODO revisit, might not want to leave '/'\n **/\nOperation.prototype.encodePathParam = function (pathParam) {\n  return encodeURIComponent(pathParam);\n};\n","'use strict';\n\nvar OperationGroup = module.exports = function (tag, description, externalDocs, operation) {\n  this.description = description;\n  this.externalDocs = externalDocs;\n  this.name = tag;\n  this.operation = operation;\n  this.operationsArray = [];\n  this.path = tag;\n  this.tag = tag;\n};\n\nOperationGroup.prototype.sort = function () {\n\n};\n\n",null,"// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    draining = true;\n    var currentQueue;\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        var i = -1;\n        while (++i < len) {\n            currentQueue[i]();\n        }\n        len = queue.length;\n    }\n    draining = false;\n}\nprocess.nextTick = function (fun) {\n    queue.push(fun);\n    if (!draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","(function (Buffer){\n(function () {\n  \"use strict\";\n\n  function btoa(str) {\n    var buffer\n      ;\n\n    if (str instanceof Buffer) {\n      buffer = str;\n    } else {\n      buffer = new Buffer(str.toString(), 'binary');\n    }\n\n    return buffer.toString('base64');\n  }\n\n  module.exports = btoa;\n}());\n\n}).call(this,require(\"buffer\").Buffer)\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9idG9hL2luZGV4LmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSIsImZpbGUiOiJnZW5lcmF0ZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICgpIHtcbiAgXCJ1c2Ugc3RyaWN0XCI7XG5cbiAgZnVuY3Rpb24gYnRvYShzdHIpIHtcbiAgICB2YXIgYnVmZmVyXG4gICAgICA7XG5cbiAgICBpZiAoc3RyIGluc3RhbmNlb2YgQnVmZmVyKSB7XG4gICAgICBidWZmZXIgPSBzdHI7XG4gICAgfSBlbHNlIHtcbiAgICAgIGJ1ZmZlciA9IG5ldyBCdWZmZXIoc3RyLnRvU3RyaW5nKCksICdiaW5hcnknKTtcbiAgICB9XG5cbiAgICByZXR1cm4gYnVmZmVyLnRvU3RyaW5nKCdiYXNlNjQnKTtcbiAgfVxuXG4gIG1vZHVsZS5leHBvcnRzID0gYnRvYTtcbn0oKSk7XG4iXX0=","/*!\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\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('is-array')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192 // not used by this implementation\n\nvar rootParent = {}\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object 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 * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Safari 5-7 lacks support for changing the `Object.prototype.constructor` property\n *     on objects.\n *\n *   - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *   - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *     incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = (function () {\n  function Bar () {}\n  try {\n    var arr = new Uint8Array(1)\n    arr.foo = function () { return 42 }\n    arr.constructor = Bar\n    return arr.foo() === 42 && // typed array instances can be augmented\n        arr.constructor === Bar && // constructor can be set\n        typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n        arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  } catch (e) {\n    return false\n  }\n})()\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\n}\n\n/**\n * Class: Buffer\n * =============\n *\n * The Buffer constructor returns instances of `Uint8Array` that are augmented\n * with function properties for all the node `Buffer` API functions. We use\n * `Uint8Array` so that square bracket notation works as expected -- it returns\n * a single octet.\n *\n * By augmenting the instances, we can avoid modifying the `Uint8Array`\n * prototype.\n */\nfunction Buffer (arg) {\n  if (!(this instanceof Buffer)) {\n    // Avoid going through an ArgumentsAdaptorTrampoline in the common case.\n    if (arguments.length > 1) return new Buffer(arg, arguments[1])\n    return new Buffer(arg)\n  }\n\n  this.length = 0\n  this.parent = undefined\n\n  // Common case.\n  if (typeof arg === 'number') {\n    return fromNumber(this, arg)\n  }\n\n  // Slightly less common case.\n  if (typeof arg === 'string') {\n    return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8')\n  }\n\n  // Unusual.\n  return fromObject(this, arg)\n}\n\nfunction fromNumber (that, length) {\n  that = allocate(that, length < 0 ? 0 : checked(length) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < length; i++) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8'\n\n  // Assumption: byteLength() return value is always < kMaxLength.\n  var length = byteLength(string, encoding) | 0\n  that = allocate(that, length)\n\n  that.write(string, encoding)\n  return that\n}\n\nfunction fromObject (that, object) {\n  if (Buffer.isBuffer(object)) return fromBuffer(that, object)\n\n  if (isArray(object)) return fromArray(that, object)\n\n  if (object == null) {\n    throw new TypeError('must start with number, buffer, array or string')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined') {\n    if (object.buffer instanceof ArrayBuffer) {\n      return fromTypedArray(that, object)\n    }\n    if (object instanceof ArrayBuffer) {\n      return fromArrayBuffer(that, object)\n    }\n  }\n\n  if (object.length) return fromArrayLike(that, object)\n\n  return fromJsonObject(that, object)\n}\n\nfunction fromBuffer (that, buffer) {\n  var length = checked(buffer.length) | 0\n  that = allocate(that, length)\n  buffer.copy(that, 0, 0, length)\n  return that\n}\n\nfunction fromArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Duplicate of fromArray() to keep fromArray() monomorphic.\nfunction fromTypedArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  // Truncating the elements is probably not what people expect from typed\n  // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior\n  // of the old Buffer constructor.\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array) {\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    array.byteLength\n    that = Buffer._augment(new Uint8Array(array))\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromTypedArray(that, new Uint8Array(array))\n  }\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object.\n// Returns a zero-length buffer for inputs that don't conform to the spec.\nfunction fromJsonObject (that, object) {\n  var array\n  var length = 0\n\n  if (object.type === 'Buffer' && isArray(object.data)) {\n    array = object.data\n    length = checked(array.length) | 0\n  }\n  that = allocate(that, length)\n\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction allocate (that, length) {\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = Buffer._augment(new Uint8Array(length))\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that.length = length\n    that._isBuffer = true\n  }\n\n  var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1\n  if (fromPool) that.parent = rootParent\n\n  return that\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nfunction SlowBuffer (subject, encoding) {\n  if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding)\n\n  var buf = new Buffer(subject, encoding)\n  delete buf.parent\n  return buf\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n  return !!(b != null && b._isBuffer)\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  var i = 0\n  var len = Math.min(x, y)\n  while (i < len) {\n    if (a[i] !== b[i]) break\n\n    ++i\n  }\n\n  if (i !== len) {\n    x = a[i]\n    y = b[i]\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 'binary':\n    case 'base64':\n    case 'raw':\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 (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.')\n\n  if (list.length === 0) {\n    return new Buffer(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 buf = new Buffer(length)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\nfunction byteLength (string, encoding) {\n  if (typeof string !== 'string') string = '' + string\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 'binary':\n      // Deprecated\n      case 'raw':\n      case 'raws':\n        return len\n      case 'utf8':\n      case 'utf-8':\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\n// pre-set for values that may exist in the future\nBuffer.prototype.length = undefined\nBuffer.prototype.parent = undefined\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  start = start | 0\n  end = end === undefined || end === Infinity ? this.length : end | 0\n\n  if (!encoding) encoding = 'utf8'\n  if (start < 0) start = 0\n  if (end > this.length) end = this.length\n  if (end <= start) return ''\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 'binary':\n        return binarySlice(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\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\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 (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return 0\n  return Buffer.compare(this, b)\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset) {\n  if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff\n  else if (byteOffset < -0x80000000) byteOffset = -0x80000000\n  byteOffset >>= 0\n\n  if (this.length === 0) return -1\n  if (byteOffset >= this.length) return -1\n\n  // Negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0)\n\n  if (typeof val === 'string') {\n    if (val.length === 0) return -1 // special case: looking for empty string always fails\n    return String.prototype.indexOf.call(this, val, byteOffset)\n  }\n  if (Buffer.isBuffer(val)) {\n    return arrayIndexOf(this, val, byteOffset)\n  }\n  if (typeof val === 'number') {\n    if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') {\n      return Uint8Array.prototype.indexOf.call(this, val, byteOffset)\n    }\n    return arrayIndexOf(this, [ val ], byteOffset)\n  }\n\n  function arrayIndexOf (arr, val, byteOffset) {\n    var foundIndex = -1\n    for (var i = 0; byteOffset + i < arr.length; i++) {\n      if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex\n      } else {\n        foundIndex = -1\n      }\n    }\n    return -1\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\n// `get` is deprecated\nBuffer.prototype.get = function get (offset) {\n  console.log('.get() is deprecated. Access using array indexes instead.')\n  return this.readUInt8(offset)\n}\n\n// `set` is deprecated\nBuffer.prototype.set = function set (v, offset) {\n  console.log('.set() is deprecated. Access using array indexes instead.')\n  return this.writeUInt8(v, offset)\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 Error('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 (isNaN(parsed)) throw new Error('Invalid hex string')\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 binaryWrite (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  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    var swap = encoding\n    encoding = offset\n    offset = length | 0\n    length = swap\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 'binary':\n        return binaryWrite(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 binarySlice (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\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = Buffer._augment(this.subarray(start, end))\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  if (newBuf.length) newBuf.parent = this.parent || this\n\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  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\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  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  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  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  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  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  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  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  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  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  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  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  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 must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('value 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) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\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) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\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  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = value\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = value\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\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 = value < 0 ? 1 : 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\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 = value < 0 ? 1 : 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\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 (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = value\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = value\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = value\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\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  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = value\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (value > max || value < min) throw new RangeError('value is out of bounds')\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  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  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 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; i++) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    target._set(this.subarray(start, start + len), targetStart)\n  }\n\n  return len\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function fill (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (end < start) throw new RangeError('end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  if (start < 0 || start >= this.length) throw new RangeError('start out of bounds')\n  if (end < 0 || end > this.length) throw new RangeError('end out of bounds')\n\n  var i\n  if (typeof value === 'number') {\n    for (i = start; i < end; i++) {\n      this[i] = value\n    }\n  } else {\n    var bytes = utf8ToBytes(value.toString())\n    var len = bytes.length\n    for (i = start; i < end; i++) {\n      this[i] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n/**\n * Creates a new `ArrayBuffer` with the *copied* memory of the buffer instance.\n * Added in Node 0.12. Only available in browsers that support ArrayBuffer.\n */\nBuffer.prototype.toArrayBuffer = function toArrayBuffer () {\n  if (typeof Uint8Array !== 'undefined') {\n    if (Buffer.TYPED_ARRAY_SUPPORT) {\n      return (new Buffer(this)).buffer\n    } else {\n      var buf = new Uint8Array(this.length)\n      for (var i = 0, len = buf.length; i < len; i += 1) {\n        buf[i] = this[i]\n      }\n      return buf.buffer\n    }\n  } else {\n    throw new TypeError('Buffer.toArrayBuffer not supported in this browser')\n  }\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar BP = Buffer.prototype\n\n/**\n * Augment a Uint8Array *instance* (not the Uint8Array class!) with Buffer methods\n */\nBuffer._augment = function _augment (arr) {\n  arr.constructor = Buffer\n  arr._isBuffer = true\n\n  // save reference to original Uint8Array set method before overwriting\n  arr._set = arr.set\n\n  // deprecated\n  arr.get = BP.get\n  arr.set = BP.set\n\n  arr.write = BP.write\n  arr.toString = BP.toString\n  arr.toLocaleString = BP.toString\n  arr.toJSON = BP.toJSON\n  arr.equals = BP.equals\n  arr.compare = BP.compare\n  arr.indexOf = BP.indexOf\n  arr.copy = BP.copy\n  arr.slice = BP.slice\n  arr.readUIntLE = BP.readUIntLE\n  arr.readUIntBE = BP.readUIntBE\n  arr.readUInt8 = BP.readUInt8\n  arr.readUInt16LE = BP.readUInt16LE\n  arr.readUInt16BE = BP.readUInt16BE\n  arr.readUInt32LE = BP.readUInt32LE\n  arr.readUInt32BE = BP.readUInt32BE\n  arr.readIntLE = BP.readIntLE\n  arr.readIntBE = BP.readIntBE\n  arr.readInt8 = BP.readInt8\n  arr.readInt16LE = BP.readInt16LE\n  arr.readInt16BE = BP.readInt16BE\n  arr.readInt32LE = BP.readInt32LE\n  arr.readInt32BE = BP.readInt32BE\n  arr.readFloatLE = BP.readFloatLE\n  arr.readFloatBE = BP.readFloatBE\n  arr.readDoubleLE = BP.readDoubleLE\n  arr.readDoubleBE = BP.readDoubleBE\n  arr.writeUInt8 = BP.writeUInt8\n  arr.writeUIntLE = BP.writeUIntLE\n  arr.writeUIntBE = BP.writeUIntBE\n  arr.writeUInt16LE = BP.writeUInt16LE\n  arr.writeUInt16BE = BP.writeUInt16BE\n  arr.writeUInt32LE = BP.writeUInt32LE\n  arr.writeUInt32BE = BP.writeUInt32BE\n  arr.writeIntLE = BP.writeIntLE\n  arr.writeIntBE = BP.writeIntBE\n  arr.writeInt8 = BP.writeInt8\n  arr.writeInt16LE = BP.writeInt16LE\n  arr.writeInt16BE = BP.writeInt16BE\n  arr.writeInt32LE = BP.writeInt32LE\n  arr.writeInt32BE = BP.writeInt32BE\n  arr.writeFloatLE = BP.writeFloatLE\n  arr.writeFloatBE = BP.writeFloatBE\n  arr.writeDoubleLE = BP.writeDoubleLE\n  arr.writeDoubleBE = BP.writeDoubleBE\n  arr.fill = BP.fill\n  arr.inspect = BP.inspect\n  arr.toArrayBuffer = BP.toArrayBuffer\n\n  return arr\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 = stringtrim(str).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 stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\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","var lookup = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\n\n;(function (exports) {\n\t'use strict';\n\n  var Arr = (typeof Uint8Array !== 'undefined')\n    ? Uint8Array\n    : Array\n\n\tvar PLUS   = '+'.charCodeAt(0)\n\tvar SLASH  = '/'.charCodeAt(0)\n\tvar NUMBER = '0'.charCodeAt(0)\n\tvar LOWER  = 'a'.charCodeAt(0)\n\tvar UPPER  = 'A'.charCodeAt(0)\n\tvar PLUS_URL_SAFE = '-'.charCodeAt(0)\n\tvar SLASH_URL_SAFE = '_'.charCodeAt(0)\n\n\tfunction decode (elt) {\n\t\tvar code = elt.charCodeAt(0)\n\t\tif (code === PLUS ||\n\t\t    code === PLUS_URL_SAFE)\n\t\t\treturn 62 // '+'\n\t\tif (code === SLASH ||\n\t\t    code === SLASH_URL_SAFE)\n\t\t\treturn 63 // '/'\n\t\tif (code < NUMBER)\n\t\t\treturn -1 //no match\n\t\tif (code < NUMBER + 10)\n\t\t\treturn code - NUMBER + 26 + 26\n\t\tif (code < UPPER + 26)\n\t\t\treturn code - UPPER\n\t\tif (code < LOWER + 26)\n\t\t\treturn code - LOWER + 26\n\t}\n\n\tfunction b64ToByteArray (b64) {\n\t\tvar i, j, l, tmp, placeHolders, arr\n\n\t\tif (b64.length % 4 > 0) {\n\t\t\tthrow new Error('Invalid string. Length must be a multiple of 4')\n\t\t}\n\n\t\t// the number of equal signs (place holders)\n\t\t// if there are two placeholders, than the two characters before it\n\t\t// represent one byte\n\t\t// if there is only one, then the three characters before it represent 2 bytes\n\t\t// this is just a cheap hack to not do indexOf twice\n\t\tvar len = b64.length\n\t\tplaceHolders = '=' === b64.charAt(len - 2) ? 2 : '=' === b64.charAt(len - 1) ? 1 : 0\n\n\t\t// base64 is 4/3 + up to two characters of the original data\n\t\tarr = new Arr(b64.length * 3 / 4 - placeHolders)\n\n\t\t// if there are placeholders, only get up to the last complete 4 chars\n\t\tl = placeHolders > 0 ? b64.length - 4 : b64.length\n\n\t\tvar L = 0\n\n\t\tfunction push (v) {\n\t\t\tarr[L++] = v\n\t\t}\n\n\t\tfor (i = 0, j = 0; i < l; i += 4, j += 3) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 18) | (decode(b64.charAt(i + 1)) << 12) | (decode(b64.charAt(i + 2)) << 6) | decode(b64.charAt(i + 3))\n\t\t\tpush((tmp & 0xFF0000) >> 16)\n\t\t\tpush((tmp & 0xFF00) >> 8)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\tif (placeHolders === 2) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 2) | (decode(b64.charAt(i + 1)) >> 4)\n\t\t\tpush(tmp & 0xFF)\n\t\t} else if (placeHolders === 1) {\n\t\t\ttmp = (decode(b64.charAt(i)) << 10) | (decode(b64.charAt(i + 1)) << 4) | (decode(b64.charAt(i + 2)) >> 2)\n\t\t\tpush((tmp >> 8) & 0xFF)\n\t\t\tpush(tmp & 0xFF)\n\t\t}\n\n\t\treturn arr\n\t}\n\n\tfunction uint8ToBase64 (uint8) {\n\t\tvar i,\n\t\t\textraBytes = uint8.length % 3, // if we have 1 byte left, pad 2 bytes\n\t\t\toutput = \"\",\n\t\t\ttemp, length\n\n\t\tfunction encode (num) {\n\t\t\treturn lookup.charAt(num)\n\t\t}\n\n\t\tfunction tripletToBase64 (num) {\n\t\t\treturn encode(num >> 18 & 0x3F) + encode(num >> 12 & 0x3F) + encode(num >> 6 & 0x3F) + encode(num & 0x3F)\n\t\t}\n\n\t\t// go through the array every three bytes, we'll deal with trailing stuff later\n\t\tfor (i = 0, length = uint8.length - extraBytes; i < length; i += 3) {\n\t\t\ttemp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n\t\t\toutput += tripletToBase64(temp)\n\t\t}\n\n\t\t// pad the end with zeros, but make sure to not forget the extra bytes\n\t\tswitch (extraBytes) {\n\t\t\tcase 1:\n\t\t\t\ttemp = uint8[uint8.length - 1]\n\t\t\t\toutput += encode(temp >> 2)\n\t\t\t\toutput += encode((temp << 4) & 0x3F)\n\t\t\t\toutput += '=='\n\t\t\t\tbreak\n\t\t\tcase 2:\n\t\t\t\ttemp = (uint8[uint8.length - 2] << 8) + (uint8[uint8.length - 1])\n\t\t\t\toutput += encode(temp >> 10)\n\t\t\t\toutput += encode((temp >> 4) & 0x3F)\n\t\t\t\toutput += encode((temp << 2) & 0x3F)\n\t\t\t\toutput += '='\n\t\t\t\tbreak\n\t\t}\n\n\t\treturn output\n\t}\n\n\texports.toByteArray = b64ToByteArray\n\texports.fromByteArray = uint8ToBase64\n}(typeof exports === 'undefined' ? (this.base64js = {}) : exports))\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","\n/**\n * isArray\n */\n\nvar isArray = Array.isArray;\n\n/**\n * toString\n */\n\nvar str = Object.prototype.toString;\n\n/**\n * Whether or not the given `val`\n * is an array.\n *\n * example:\n *\n *        isArray([]);\n *        // > true\n *        isArray(arguments);\n *        // > false\n *        isArray('');\n *        // > false\n *\n * @param {mixed} val\n * @return {bool}\n */\n\nmodule.exports = isArray || function (val) {\n  return !! val && '[object Array]' == str.call(val);\n};\n","/* jshint node: true */\n(function () {\n    \"use strict\";\n\n    function CookieAccessInfo(domain, path, secure, script) {\n        if (this instanceof CookieAccessInfo) {\n            this.domain = domain || undefined;\n            this.path = path || \"/\";\n            this.secure = !!secure;\n            this.script = !!script;\n            return this;\n        }\n        return new CookieAccessInfo(domain, path, secure, script);\n    }\n    exports.CookieAccessInfo = CookieAccessInfo;\n\n    function Cookie(cookiestr, request_domain, request_path) {\n        if (cookiestr instanceof Cookie) {\n            return cookiestr;\n        }\n        if (this instanceof Cookie) {\n            this.name = null;\n            this.value = null;\n            this.expiration_date = Infinity;\n            this.path = String(request_path || \"/\");\n            this.explicit_path = false;\n            this.domain = request_domain || null;\n            this.explicit_domain = false;\n            this.secure = false; //how to define default?\n            this.noscript = false; //httponly\n            if (cookiestr) {\n                this.parse(cookiestr, request_domain, request_path);\n            }\n            return this;\n        }\n        return new Cookie(cookiestr, request_domain, request_path);\n    }\n    exports.Cookie = Cookie;\n\n    Cookie.prototype.toString = function toString() {\n        var str = [this.name + \"=\" + this.value];\n        if (this.expiration_date !== Infinity) {\n            str.push(\"expires=\" + (new Date(this.expiration_date)).toGMTString());\n        }\n        if (this.domain) {\n            str.push(\"domain=\" + this.domain);\n        }\n        if (this.path) {\n            str.push(\"path=\" + this.path);\n        }\n        if (this.secure) {\n            str.push(\"secure\");\n        }\n        if (this.noscript) {\n            str.push(\"httponly\");\n        }\n        return str.join(\"; \");\n    };\n\n    Cookie.prototype.toValueString = function toValueString() {\n        return this.name + \"=\" + this.value;\n    };\n\n    var cookie_str_splitter = /[:](?=\\s*[a-zA-Z0-9_\\-]+\\s*[=])/g;\n    Cookie.prototype.parse = function parse(str, request_domain, request_path) {\n        if (this instanceof Cookie) {\n            var parts = str.split(\";\").filter(function (value) {\n                    return !!value;\n                }),\n                pair = parts[0].match(/([^=]+)=([\\s\\S]*)/),\n                key = pair[1],\n                value = pair[2],\n                i;\n            this.name = key;\n            this.value = value;\n\n            for (i = 1; i < parts.length; i += 1) {\n                pair = parts[i].match(/([^=]+)(?:=([\\s\\S]*))?/);\n                key = pair[1].trim().toLowerCase();\n                value = pair[2];\n                switch (key) {\n                case \"httponly\":\n                    this.noscript = true;\n                    break;\n                case \"expires\":\n                    this.expiration_date = value ?\n                            Number(Date.parse(value)) :\n                            Infinity;\n                    break;\n                case \"path\":\n                    this.path = value ?\n                            value.trim() :\n                            \"\";\n                    this.explicit_path = true;\n                    break;\n                case \"domain\":\n                    this.domain = value ?\n                            value.trim() :\n                            \"\";\n                    this.explicit_domain = !!this.domain;\n                    break;\n                case \"secure\":\n                    this.secure = true;\n                    break;\n                }\n            }\n\n            if (!this.explicit_path) {\n               this.path = request_path || \"/\";\n            }\n            if (!this.explicit_domain) {\n               this.domain = request_domain;\n            }\n\n            return this;\n        }\n        return new Cookie().parse(str, request_domain, request_path);\n    };\n\n    Cookie.prototype.matches = function matches(access_info) {\n        if (this.noscript && access_info.script ||\n                this.secure && !access_info.secure ||\n                !this.collidesWith(access_info)) {\n            return false;\n        }\n        return true;\n    };\n\n    Cookie.prototype.collidesWith = function collidesWith(access_info) {\n        if ((this.path && !access_info.path) || (this.domain && !access_info.domain)) {\n            return false;\n        }\n        if (this.path && access_info.path.indexOf(this.path) !== 0) {\n            return false;\n        }\n        if (this.explicit_path && access_info.path.indexOf( this.path ) !== 0) {\n           return false;\n        }\n        var access_domain = access_info.domain && access_info.domain.replace(/^[\\.]/,'');\n        var cookie_domain = this.domain && this.domain.replace(/^[\\.]/,'');\n        if (cookie_domain === access_domain) {\n            return true;\n        }\n        if (cookie_domain) {\n            if (!this.explicit_domain) {\n                return false; // we already checked if the domains were exactly the same\n            }\n            var wildcard = access_domain.indexOf(cookie_domain);\n            if (wildcard === -1 || wildcard !== access_domain.length - cookie_domain.length) {\n                return false;\n            }\n            return true;\n        }\n        return true;\n    };\n\n    function CookieJar() {\n        var cookies, cookies_list, collidable_cookie;\n        if (this instanceof CookieJar) {\n            cookies = Object.create(null); //name: [Cookie]\n\n            this.setCookie = function setCookie(cookie, request_domain, request_path) {\n                var remove, i;\n                cookie = new Cookie(cookie, request_domain, request_path);\n                //Delete the cookie if the set is past the current time\n                remove = cookie.expiration_date <= Date.now();\n                if (cookies[cookie.name] !== undefined) {\n                    cookies_list = cookies[cookie.name];\n                    for (i = 0; i < cookies_list.length; i += 1) {\n                        collidable_cookie = cookies_list[i];\n                        if (collidable_cookie.collidesWith(cookie)) {\n                            if (remove) {\n                                cookies_list.splice(i, 1);\n                                if (cookies_list.length === 0) {\n                                    delete cookies[cookie.name];\n                                }\n                                return false;\n                            }\n                            cookies_list[i] = cookie;\n                            return cookie;\n                        }\n                    }\n                    if (remove) {\n                        return false;\n                    }\n                    cookies_list.push(cookie);\n                    return cookie;\n                }\n                if (remove) {\n                    return false;\n                }\n                cookies[cookie.name] = [cookie];\n                return cookies[cookie.name];\n            };\n            //returns a cookie\n            this.getCookie = function getCookie(cookie_name, access_info) {\n                var cookie, i;\n                cookies_list = cookies[cookie_name];\n                if (!cookies_list) {\n                    return;\n                }\n                for (i = 0; i < cookies_list.length; i += 1) {\n                    cookie = cookies_list[i];\n                    if (cookie.expiration_date <= Date.now()) {\n                        if (cookies_list.length === 0) {\n                            delete cookies[cookie.name];\n                        }\n                        continue;\n                    }\n\n                    if (cookie.matches(access_info)) {\n                        return cookie;\n                    }\n                }\n            };\n            //returns a list of cookies\n            this.getCookies = function getCookies(access_info) {\n                var matches = [], cookie_name, cookie;\n                for (cookie_name in cookies) {\n                    cookie = this.getCookie(cookie_name, access_info);\n                    if (cookie) {\n                        matches.push(cookie);\n                    }\n                }\n                matches.toString = function toString() {\n                    return matches.join(\":\");\n                };\n                matches.toValueString = function toValueString() {\n                    return matches.map(function (c) {\n                        return c.toValueString();\n                    }).join(';');\n                };\n                return matches;\n            };\n\n            return this;\n        }\n        return new CookieJar();\n    }\n    exports.CookieJar = CookieJar;\n\n    //returns list of cookies that were set correctly. Cookies that are expired and removed are not returned.\n    CookieJar.prototype.setCookies = function setCookies(cookies, request_domain, request_path) {\n        cookies = Array.isArray(cookies) ?\n                cookies :\n                cookies.split(cookie_str_splitter);\n        var successful = [],\n            i,\n            cookie;\n        cookies = cookies.map(function(item){\n            return new Cookie(item, request_domain, request_path);\n        });\n        for (i = 0; i < cookies.length; i += 1) {\n            cookie = cookies[i];\n            if (this.setCookie(cookie, request_domain, request_path)) {\n                successful.push(cookie);\n            }\n        }\n        return successful;\n    };\n}());\n","'use strict';\n\n\nvar yaml = require('./lib/js-yaml.js');\n\n\nmodule.exports = yaml;\n","'use strict';\n\n\nvar loader = require('./js-yaml/loader');\nvar dumper = require('./js-yaml/dumper');\n\n\nfunction deprecated(name) {\n  return function () {\n    throw new Error('Function ' + name + ' is deprecated and cannot be used.');\n  };\n}\n\n\nmodule.exports.Type                = require('./js-yaml/type');\nmodule.exports.Schema              = require('./js-yaml/schema');\nmodule.exports.FAILSAFE_SCHEMA     = require('./js-yaml/schema/failsafe');\nmodule.exports.JSON_SCHEMA         = require('./js-yaml/schema/json');\nmodule.exports.CORE_SCHEMA         = require('./js-yaml/schema/core');\nmodule.exports.DEFAULT_SAFE_SCHEMA = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_FULL_SCHEMA = require('./js-yaml/schema/default_full');\nmodule.exports.load                = loader.load;\nmodule.exports.loadAll             = loader.loadAll;\nmodule.exports.safeLoad            = loader.safeLoad;\nmodule.exports.safeLoadAll         = loader.safeLoadAll;\nmodule.exports.dump                = dumper.dump;\nmodule.exports.safeDump            = dumper.safeDump;\nmodule.exports.YAMLException       = require('./js-yaml/exception');\n\n// Deprecated schema names from JS-YAML 2.0.x\nmodule.exports.MINIMAL_SCHEMA = require('./js-yaml/schema/failsafe');\nmodule.exports.SAFE_SCHEMA    = require('./js-yaml/schema/default_safe');\nmodule.exports.DEFAULT_SCHEMA = require('./js-yaml/schema/default_full');\n\n// Deprecated functions from JS-YAML 1.x.x\nmodule.exports.scan           = deprecated('scan');\nmodule.exports.parse          = deprecated('parse');\nmodule.exports.compose        = deprecated('compose');\nmodule.exports.addConstructor = deprecated('addConstructor');\n","'use strict';\n\n\nfunction isNothing(subject) {\n  return (typeof subject === 'undefined') || (null === subject);\n}\n\n\nfunction isObject(subject) {\n  return (typeof subject === 'object') && (null !== subject);\n}\n\n\nfunction toArray(sequence) {\n  if (Array.isArray(sequence)) {\n    return sequence;\n  } else if (isNothing(sequence)) {\n    return [];\n  }\n  return [ sequence ];\n}\n\n\nfunction extend(target, source) {\n  var index, length, key, sourceKeys;\n\n  if (source) {\n    sourceKeys = Object.keys(source);\n\n    for (index = 0, length = sourceKeys.length; index < length; index += 1) {\n      key = sourceKeys[index];\n      target[key] = source[key];\n    }\n  }\n\n  return target;\n}\n\n\nfunction repeat(string, count) {\n  var result = '', cycle;\n\n  for (cycle = 0; cycle < count; cycle += 1) {\n    result += string;\n  }\n\n  return result;\n}\n\n\nfunction isNegativeZero(number) {\n  return (0 === number) && (Number.NEGATIVE_INFINITY === 1 / number);\n}\n\n\nmodule.exports.isNothing      = isNothing;\nmodule.exports.isObject       = isObject;\nmodule.exports.toArray        = toArray;\nmodule.exports.repeat         = repeat;\nmodule.exports.isNegativeZero = isNegativeZero;\nmodule.exports.extend         = extend;\n","'use strict';\n\n/*eslint-disable no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\n\nvar _toString       = Object.prototype.toString;\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar CHAR_TAB                  = 0x09; /* Tab */\nvar CHAR_LINE_FEED            = 0x0A; /* LF */\nvar CHAR_CARRIAGE_RETURN      = 0x0D; /* CR */\nvar CHAR_SPACE                = 0x20; /* Space */\nvar CHAR_EXCLAMATION          = 0x21; /* ! */\nvar CHAR_DOUBLE_QUOTE         = 0x22; /* \" */\nvar CHAR_SHARP                = 0x23; /* # */\nvar CHAR_PERCENT              = 0x25; /* % */\nvar CHAR_AMPERSAND            = 0x26; /* & */\nvar CHAR_SINGLE_QUOTE         = 0x27; /* ' */\nvar CHAR_ASTERISK             = 0x2A; /* * */\nvar CHAR_COMMA                = 0x2C; /* , */\nvar CHAR_MINUS                = 0x2D; /* - */\nvar CHAR_COLON                = 0x3A; /* : */\nvar CHAR_GREATER_THAN         = 0x3E; /* > */\nvar CHAR_QUESTION             = 0x3F; /* ? */\nvar CHAR_COMMERCIAL_AT        = 0x40; /* @ */\nvar CHAR_LEFT_SQUARE_BRACKET  = 0x5B; /* [ */\nvar CHAR_RIGHT_SQUARE_BRACKET = 0x5D; /* ] */\nvar CHAR_GRAVE_ACCENT         = 0x60; /* ` */\nvar CHAR_LEFT_CURLY_BRACKET   = 0x7B; /* { */\nvar CHAR_VERTICAL_LINE        = 0x7C; /* | */\nvar CHAR_RIGHT_CURLY_BRACKET  = 0x7D; /* } */\n\nvar ESCAPE_SEQUENCES = {};\n\nESCAPE_SEQUENCES[0x00]   = '\\\\0';\nESCAPE_SEQUENCES[0x07]   = '\\\\a';\nESCAPE_SEQUENCES[0x08]   = '\\\\b';\nESCAPE_SEQUENCES[0x09]   = '\\\\t';\nESCAPE_SEQUENCES[0x0A]   = '\\\\n';\nESCAPE_SEQUENCES[0x0B]   = '\\\\v';\nESCAPE_SEQUENCES[0x0C]   = '\\\\f';\nESCAPE_SEQUENCES[0x0D]   = '\\\\r';\nESCAPE_SEQUENCES[0x1B]   = '\\\\e';\nESCAPE_SEQUENCES[0x22]   = '\\\\\"';\nESCAPE_SEQUENCES[0x5C]   = '\\\\\\\\';\nESCAPE_SEQUENCES[0x85]   = '\\\\N';\nESCAPE_SEQUENCES[0xA0]   = '\\\\_';\nESCAPE_SEQUENCES[0x2028] = '\\\\L';\nESCAPE_SEQUENCES[0x2029] = '\\\\P';\n\nvar DEPRECATED_BOOLEANS_SYNTAX = [\n  'y', 'Y', 'yes', 'Yes', 'YES', 'on', 'On', 'ON',\n  'n', 'N', 'no', 'No', 'NO', 'off', 'Off', 'OFF'\n];\n\nfunction compileStyleMap(schema, map) {\n  var result, keys, index, length, tag, style, type;\n\n  if (null === map) {\n    return {};\n  }\n\n  result = {};\n  keys = Object.keys(map);\n\n  for (index = 0, length = keys.length; index < length; index += 1) {\n    tag = keys[index];\n    style = String(map[tag]);\n\n    if ('!!' === tag.slice(0, 2)) {\n      tag = 'tag:yaml.org,2002:' + tag.slice(2);\n    }\n\n    type = schema.compiledTypeMap[tag];\n\n    if (type && _hasOwnProperty.call(type.styleAliases, style)) {\n      style = type.styleAliases[style];\n    }\n\n    result[tag] = style;\n  }\n\n  return result;\n}\n\nfunction encodeHex(character) {\n  var string, handle, length;\n\n  string = character.toString(16).toUpperCase();\n\n  if (character <= 0xFF) {\n    handle = 'x';\n    length = 2;\n  } else if (character <= 0xFFFF) {\n    handle = 'u';\n    length = 4;\n  } else if (character <= 0xFFFFFFFF) {\n    handle = 'U';\n    length = 8;\n  } else {\n    throw new YAMLException('code point within a string may not be greater than 0xFFFFFFFF');\n  }\n\n  return '\\\\' + handle + common.repeat('0', length - string.length) + string;\n}\n\nfunction State(options) {\n  this.schema      = options['schema'] || DEFAULT_FULL_SCHEMA;\n  this.indent      = Math.max(1, (options['indent'] || 2));\n  this.skipInvalid = options['skipInvalid'] || false;\n  this.flowLevel   = (common.isNothing(options['flowLevel']) ? -1 : options['flowLevel']);\n  this.styleMap    = compileStyleMap(this.schema, options['styles'] || null);\n  this.sortKeys    = options['sortKeys'] || false;\n  this.lineWidth    = options['lineWidth'] || 80;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.explicitTypes = this.schema.compiledExplicit;\n\n  this.tag = null;\n  this.result = '';\n\n  this.duplicates = [];\n  this.usedDuplicates = null;\n}\n\nfunction indentString(string, spaces) {\n  var ind = common.repeat(' ', spaces),\n      position = 0,\n      next = -1,\n      result = '',\n      line,\n      length = string.length;\n\n  while (position < length) {\n    next = string.indexOf('\\n', position);\n    if (next === -1) {\n      line = string.slice(position);\n      position = length;\n    } else {\n      line = string.slice(position, next + 1);\n      position = next + 1;\n    }\n    if (line.length && line !== '\\n') {\n      result += ind;\n    }\n    result += line;\n  }\n\n  return result;\n}\n\nfunction generateNextLine(state, level) {\n  return '\\n' + common.repeat(' ', state.indent * level);\n}\n\nfunction testImplicitResolving(state, str) {\n  var index, length, type;\n\n  for (index = 0, length = state.implicitTypes.length; index < length; index += 1) {\n    type = state.implicitTypes[index];\n\n    if (type.resolve(str)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction StringBuilder(source) {\n  this.source = source;\n  this.result = '';\n  this.checkpoint = 0;\n}\n\nStringBuilder.prototype.takeUpTo = function (position) {\n  var er;\n\n  if (position < this.checkpoint) {\n    er = new Error('position should be > checkpoint');\n    er.position = position;\n    er.checkpoint = this.checkpoint;\n    throw er;\n  }\n\n  this.result += this.source.slice(this.checkpoint, position);\n  this.checkpoint = position;\n  return this;\n};\n\nStringBuilder.prototype.escapeChar = function () {\n  var character, esc;\n\n  character = this.source.charCodeAt(this.checkpoint);\n  esc = ESCAPE_SEQUENCES[character] || encodeHex(character);\n  this.result += esc;\n  this.checkpoint += 1;\n\n  return this;\n};\n\nStringBuilder.prototype.finish = function () {\n  if (this.source.length > this.checkpoint) {\n    this.takeUpTo(this.source.length);\n  }\n};\n\nfunction writeScalar(state, object, level, iskey) {\n  var simple, first, spaceWrap, folded, literal, single, double,\n      sawLineFeed, linePosition, longestLine, indent, max, character,\n      position, escapeSeq, hexEsc, previous, lineLength, modifier,\n      trailingLineBreaks, result;\n\n  if (0 === object.length) {\n    state.dump = \"''\";\n    return;\n  }\n\n  if (-1 !== DEPRECATED_BOOLEANS_SYNTAX.indexOf(object)) {\n    state.dump = \"'\" + object + \"'\";\n    return;\n  }\n\n  simple = true;\n  first = object.length ? object.charCodeAt(0) : 0;\n  spaceWrap = (CHAR_SPACE === first ||\n               CHAR_SPACE === object.charCodeAt(object.length - 1));\n\n  // Simplified check for restricted first characters\n  // http://www.yaml.org/spec/1.2/spec.html#ns-plain-first%28c%29\n  if (CHAR_MINUS         === first ||\n      CHAR_QUESTION      === first ||\n      CHAR_COMMERCIAL_AT === first ||\n      CHAR_GRAVE_ACCENT  === first) {\n    simple = false;\n  }\n\n  // can only use > and | if not wrapped in spaces or is not a key.\n  if (spaceWrap) {\n    simple = false;\n    folded = false;\n    literal = false;\n  } else {\n    folded = !iskey;\n    literal = !iskey;\n  }\n\n  single = true;\n  double = new StringBuilder(object);\n\n  sawLineFeed = false;\n  linePosition = 0;\n  longestLine = 0;\n\n  indent = state.indent * level;\n  max = state.lineWidth;\n  if (max === -1) {\n    // Replace -1 with biggest ingeger number according to\n    // http://ecma262-5.com/ELS5_HTML.htm#Section_8.5\n    max = 9007199254740991;\n  }\n\n  if (indent < 40) {\n    max -= indent;\n  } else {\n    max = 40;\n  }\n\n  for (position = 0; position < object.length; position++) {\n    character = object.charCodeAt(position);\n    if (simple) {\n      // Characters that can never appear in the simple scalar\n      if (!simpleChar(character)) {\n        simple = false;\n      } else {\n        // Still simple.  If we make it all the way through like\n        // this, then we can just dump the string as-is.\n        continue;\n      }\n    }\n\n    if (single && character === CHAR_SINGLE_QUOTE) {\n      single = false;\n    }\n\n    escapeSeq = ESCAPE_SEQUENCES[character];\n    hexEsc = needsHexEscape(character);\n\n    if (!escapeSeq && !hexEsc) {\n      continue;\n    }\n\n    if (character !== CHAR_LINE_FEED &&\n        character !== CHAR_DOUBLE_QUOTE &&\n        character !== CHAR_SINGLE_QUOTE) {\n      folded = false;\n      literal = false;\n    } else if (character === CHAR_LINE_FEED) {\n      sawLineFeed = true;\n      single = false;\n      if (position > 0) {\n        previous = object.charCodeAt(position - 1);\n        if (previous === CHAR_SPACE) {\n          literal = false;\n          folded = false;\n        }\n      }\n      if (folded) {\n        lineLength = position - linePosition;\n        linePosition = position;\n        if (lineLength > longestLine) {\n          longestLine = lineLength;\n        }\n      }\n    }\n\n    if (character !== CHAR_DOUBLE_QUOTE) {\n      single = false;\n    }\n\n    double.takeUpTo(position);\n    double.escapeChar();\n  }\n\n  if (simple && testImplicitResolving(state, object)) {\n    simple = false;\n  }\n\n  modifier = '';\n  if (folded || literal) {\n    trailingLineBreaks = 0;\n    if (object.charCodeAt(object.length - 1) === CHAR_LINE_FEED) {\n      trailingLineBreaks += 1;\n      if (object.charCodeAt(object.length - 2) === CHAR_LINE_FEED) {\n        trailingLineBreaks += 1;\n      }\n    }\n\n    if (trailingLineBreaks === 0) {\n      modifier = '-';\n    } else if (trailingLineBreaks === 2) {\n      modifier = '+';\n    }\n  }\n\n  if (literal && longestLine < max) {\n    folded = false;\n  }\n\n  // If it's literally one line, then don't bother with the literal.\n  // We may still want to do a fold, though, if it's a super long line.\n  if (!sawLineFeed) {\n    literal = false;\n  }\n\n  if (simple) {\n    state.dump = object;\n  } else if (single) {\n    state.dump = '\\'' + object + '\\'';\n  } else if (folded) {\n    result = fold(object, max);\n    state.dump = '>' + modifier + '\\n' + indentString(result, indent);\n  } else if (literal) {\n    if (!modifier) {\n      object = object.replace(/\\n$/, '');\n    }\n    state.dump = '|' + modifier + '\\n' + indentString(object, indent);\n  } else if (double) {\n    double.finish();\n    state.dump = '\"' + double.result + '\"';\n  } else {\n    throw new Error('Failed to dump scalar value');\n  }\n\n  return;\n}\n\n// The `trailing` var is a regexp match of any trailing `\\n` characters.\n//\n// There are three cases we care about:\n//\n// 1. One trailing `\\n` on the string.  Just use `|` or `>`.\n//    This is the assumed default. (trailing = null)\n// 2. No trailing `\\n` on the string.  Use `|-` or `>-` to \"chomp\" the end.\n// 3. More than one trailing `\\n` on the string.  Use `|+` or `>+`.\n//\n// In the case of `>+`, these line breaks are *not* doubled (like the line\n// breaks within the string), so it's important to only end with the exact\n// same number as we started.\nfunction fold(object, max) {\n  var result = '',\n      position = 0,\n      length = object.length,\n      trailing = /\\n+$/.exec(object),\n      newLine;\n\n  if (trailing) {\n    length = trailing.index + 1;\n  }\n\n  while (position < length) {\n    newLine = object.indexOf('\\n', position);\n    if (newLine > length || newLine === -1) {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, length), max);\n      position = length;\n    } else {\n      if (result) {\n        result += '\\n\\n';\n      }\n      result += foldLine(object.slice(position, newLine), max);\n      position = newLine + 1;\n    }\n  }\n  if (trailing && trailing[0] !== '\\n') {\n    result += trailing[0];\n  }\n\n  return result;\n}\n\nfunction foldLine(line, max) {\n  if (line === '') {\n    return line;\n  }\n\n  var foldRe = /[^\\s] [^\\s]/g,\n      result = '',\n      prevMatch = 0,\n      foldStart = 0,\n      match = foldRe.exec(line),\n      index,\n      foldEnd,\n      folded;\n\n  while (match) {\n    index = match.index;\n\n    // when we cross the max len, if the previous match would've\n    // been ok, use that one, and carry on.  If there was no previous\n    // match on this fold section, then just have a long line.\n    if (index - foldStart > max) {\n      if (prevMatch !== foldStart) {\n        foldEnd = prevMatch;\n      } else {\n        foldEnd = index;\n      }\n\n      if (result) {\n        result += '\\n';\n      }\n      folded = line.slice(foldStart, foldEnd);\n      result += folded;\n      foldStart = foldEnd + 1;\n    }\n    prevMatch = index + 1;\n    match = foldRe.exec(line);\n  }\n\n  if (result) {\n    result += '\\n';\n  }\n\n  // if we end up with one last word at the end, then the last bit might\n  // be slightly bigger than we wanted, because we exited out of the loop.\n  if (foldStart !== prevMatch && line.length - foldStart > max) {\n    result += line.slice(foldStart, prevMatch) + '\\n' +\n              line.slice(prevMatch + 1);\n  } else {\n    result += line.slice(foldStart);\n  }\n\n  return result;\n}\n\n// Returns true if character can be found in a simple scalar\nfunction simpleChar(character) {\n  return CHAR_TAB                  !== character &&\n         CHAR_LINE_FEED            !== character &&\n         CHAR_CARRIAGE_RETURN      !== character &&\n         CHAR_COMMA                !== character &&\n         CHAR_LEFT_SQUARE_BRACKET  !== character &&\n         CHAR_RIGHT_SQUARE_BRACKET !== character &&\n         CHAR_LEFT_CURLY_BRACKET   !== character &&\n         CHAR_RIGHT_CURLY_BRACKET  !== character &&\n         CHAR_SHARP                !== character &&\n         CHAR_AMPERSAND            !== character &&\n         CHAR_ASTERISK             !== character &&\n         CHAR_EXCLAMATION          !== character &&\n         CHAR_VERTICAL_LINE        !== character &&\n         CHAR_GREATER_THAN         !== character &&\n         CHAR_SINGLE_QUOTE         !== character &&\n         CHAR_DOUBLE_QUOTE         !== character &&\n         CHAR_PERCENT              !== character &&\n         CHAR_COLON                !== character &&\n         !ESCAPE_SEQUENCES[character]            &&\n         !needsHexEscape(character);\n}\n\n// Returns true if the character code needs to be escaped.\nfunction needsHexEscape(character) {\n  return !((0x00020 <= character && character <= 0x00007E) ||\n           (0x00085 === character)                         ||\n           (0x000A0 <= character && character <= 0x00D7FF) ||\n           (0x0E000 <= character && character <= 0x00FFFD) ||\n           (0x10000 <= character && character <= 0x10FFFF));\n}\n\nfunction writeFlowSequence(state, level, object) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level, object[index], false, false)) {\n      if (0 !== index) {\n        _result += ', ';\n      }\n      _result += state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = '[' + _result + ']';\n}\n\nfunction writeBlockSequence(state, level, object, compact) {\n  var _result = '',\n      _tag    = state.tag,\n      index,\n      length;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    // Write only valid elements.\n    if (writeNode(state, level + 1, object[index], true, true)) {\n      if (!compact || 0 !== index) {\n        _result += generateNextLine(state, level);\n      }\n      _result += '- ' + state.dump;\n    }\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '[]'; // Empty sequence if no valid values.\n}\n\nfunction writeFlowMapping(state, level, object) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      pairBuffer;\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (0 !== index) {\n      pairBuffer += ', ';\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level, objectKey, false, false)) {\n      continue; // Skip this pair because of invalid key;\n    }\n\n    if (state.dump.length > 1024) {\n      pairBuffer += '? ';\n    }\n\n    pairBuffer += state.dump + ': ';\n\n    if (!writeNode(state, level, objectValue, false, false)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = '{' + _result + '}';\n}\n\nfunction writeBlockMapping(state, level, object, compact) {\n  var _result       = '',\n      _tag          = state.tag,\n      objectKeyList = Object.keys(object),\n      index,\n      length,\n      objectKey,\n      objectValue,\n      explicitPair,\n      pairBuffer;\n\n  // Allow sorting keys so that the output file is deterministic\n  if (state.sortKeys === true) {\n    // Default sorting\n    objectKeyList.sort();\n  } else if (typeof state.sortKeys === 'function') {\n    // Custom sort function\n    objectKeyList.sort(state.sortKeys);\n  } else if (state.sortKeys) {\n    // Something is wrong\n    throw new YAMLException('sortKeys must be a boolean or a function');\n  }\n\n  for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n    pairBuffer = '';\n\n    if (!compact || 0 !== index) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    objectKey = objectKeyList[index];\n    objectValue = object[objectKey];\n\n    if (!writeNode(state, level + 1, objectKey, true, true, true)) {\n      continue; // Skip this pair because of invalid key.\n    }\n\n    explicitPair = (null !== state.tag && '?' !== state.tag) ||\n                   (state.dump && state.dump.length > 1024);\n\n    if (explicitPair) {\n      if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n        pairBuffer += '?';\n      } else {\n        pairBuffer += '? ';\n      }\n    }\n\n    pairBuffer += state.dump;\n\n    if (explicitPair) {\n      pairBuffer += generateNextLine(state, level);\n    }\n\n    if (!writeNode(state, level + 1, objectValue, true, explicitPair)) {\n      continue; // Skip this pair because of invalid value.\n    }\n\n    if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n      pairBuffer += ':';\n    } else {\n      pairBuffer += ': ';\n    }\n\n    pairBuffer += state.dump;\n\n    // Both key and value are valid.\n    _result += pairBuffer;\n  }\n\n  state.tag = _tag;\n  state.dump = _result || '{}'; // Empty mapping if no valid pairs.\n}\n\nfunction detectType(state, object, explicit) {\n  var _result, typeList, index, length, type, style;\n\n  typeList = explicit ? state.explicitTypes : state.implicitTypes;\n\n  for (index = 0, length = typeList.length; index < length; index += 1) {\n    type = typeList[index];\n\n    if ((type.instanceOf  || type.predicate) &&\n        (!type.instanceOf || (('object' === typeof object) && (object instanceof type.instanceOf))) &&\n        (!type.predicate  || type.predicate(object))) {\n\n      state.tag = explicit ? type.tag : '?';\n\n      if (type.represent) {\n        style = state.styleMap[type.tag] || type.defaultStyle;\n\n        if ('[object Function]' === _toString.call(type.represent)) {\n          _result = type.represent(object, style);\n        } else if (_hasOwnProperty.call(type.represent, style)) {\n          _result = type.represent[style](object, style);\n        } else {\n          throw new YAMLException('!<' + type.tag + '> tag resolver accepts not \"' + style + '\" style');\n        }\n\n        state.dump = _result;\n      }\n\n      return true;\n    }\n  }\n\n  return false;\n}\n\n// Serializes `object` and writes it to global `result`.\n// Returns true on success, or false on invalid object.\n//\nfunction writeNode(state, level, object, block, compact, iskey) {\n  state.tag = null;\n  state.dump = object;\n\n  if (!detectType(state, object, false)) {\n    detectType(state, object, true);\n  }\n\n  var type = _toString.call(state.dump);\n\n  if (block) {\n    block = (0 > state.flowLevel || state.flowLevel > level);\n  }\n\n  var objectOrArray = '[object Object]' === type || '[object Array]' === type,\n      duplicateIndex,\n      duplicate;\n\n  if (objectOrArray) {\n    duplicateIndex = state.duplicates.indexOf(object);\n    duplicate = duplicateIndex !== -1;\n  }\n\n  if ((null !== state.tag && '?' !== state.tag) || duplicate || (2 !== state.indent && level > 0)) {\n    compact = false;\n  }\n\n  if (duplicate && state.usedDuplicates[duplicateIndex]) {\n    state.dump = '*ref_' + duplicateIndex;\n  } else {\n    if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) {\n      state.usedDuplicates[duplicateIndex] = true;\n    }\n    if ('[object Object]' === type) {\n      if (block && (0 !== Object.keys(state.dump).length)) {\n        writeBlockMapping(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + state.dump;\n        }\n      } else {\n        writeFlowMapping(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object Array]' === type) {\n      if (block && (0 !== state.dump.length)) {\n        writeBlockSequence(state, level, state.dump, compact);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + state.dump;\n        }\n      } else {\n        writeFlowSequence(state, level, state.dump);\n        if (duplicate) {\n          state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n        }\n      }\n    } else if ('[object String]' === type) {\n      if ('?' !== state.tag) {\n        writeScalar(state, state.dump, level, iskey);\n      }\n    } else {\n      if (state.skipInvalid) {\n        return false;\n      }\n      throw new YAMLException('unacceptable kind of an object to dump ' + type);\n    }\n\n    if (null !== state.tag && '?' !== state.tag) {\n      state.dump = '!<' + state.tag + '> ' + state.dump;\n    }\n  }\n\n  return true;\n}\n\nfunction getDuplicateReferences(object, state) {\n  var objects = [],\n      duplicatesIndexes = [],\n      index,\n      length;\n\n  inspectNode(object, objects, duplicatesIndexes);\n\n  for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) {\n    state.duplicates.push(objects[duplicatesIndexes[index]]);\n  }\n  state.usedDuplicates = new Array(length);\n}\n\nfunction inspectNode(object, objects, duplicatesIndexes) {\n  var objectKeyList,\n      index,\n      length;\n\n  if (null !== object && 'object' === typeof object) {\n    index = objects.indexOf(object);\n    if (-1 !== index) {\n      if (-1 === duplicatesIndexes.indexOf(index)) {\n        duplicatesIndexes.push(index);\n      }\n    } else {\n      objects.push(object);\n\n      if (Array.isArray(object)) {\n        for (index = 0, length = object.length; index < length; index += 1) {\n          inspectNode(object[index], objects, duplicatesIndexes);\n        }\n      } else {\n        objectKeyList = Object.keys(object);\n\n        for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n          inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes);\n        }\n      }\n    }\n  }\n}\n\nfunction dump(input, options) {\n  options = options || {};\n\n  var state = new State(options);\n\n  getDuplicateReferences(input, state);\n\n  if (writeNode(state, 0, input, true, true)) {\n    return state.dump + '\\n';\n  }\n  return '';\n}\n\nfunction safeDump(input, options) {\n  return dump(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\nmodule.exports.dump     = dump;\nmodule.exports.safeDump = safeDump;\n","// YAML error class. http://stackoverflow.com/questions/8458984\n//\n'use strict';\n\n\nvar inherits = require('inherit');\n\n\nfunction YAMLException(reason, mark) {\n  // Super constructor\n  Error.call(this);\n\n  // Include stack trace in error object\n  if (Error.captureStackTrace) {\n    // Chrome and NodeJS\n    Error.captureStackTrace(this, this.constructor);\n  } else {\n    // FF, IE 10+ and Safari 6+. Fallback for others\n    this.stack = (new Error()).stack || '';\n  }\n\n  this.name = 'YAMLException';\n  this.reason = reason;\n  this.mark = mark;\n  this.message = (this.reason || '(unknown reason)') + (this.mark ? ' ' + this.mark.toString() : '');\n}\n\n\n// Inherit from Error\ninherits(YAMLException, Error);\n\n\nYAMLException.prototype.toString = function toString(compact) {\n  var result = this.name + ': ';\n\n  result += this.reason || '(unknown reason)';\n\n  if (!compact && this.mark) {\n    result += ' ' + this.mark.toString();\n  }\n\n  return result;\n};\n\n\nmodule.exports = YAMLException;\n","'use strict';\n\n/*eslint-disable max-len,no-use-before-define*/\n\nvar common              = require('./common');\nvar YAMLException       = require('./exception');\nvar Mark                = require('./mark');\nvar DEFAULT_SAFE_SCHEMA = require('./schema/default_safe');\nvar DEFAULT_FULL_SCHEMA = require('./schema/default_full');\n\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\n\nvar CONTEXT_FLOW_IN   = 1;\nvar CONTEXT_FLOW_OUT  = 2;\nvar CONTEXT_BLOCK_IN  = 3;\nvar CONTEXT_BLOCK_OUT = 4;\n\n\nvar CHOMPING_CLIP  = 1;\nvar CHOMPING_STRIP = 2;\nvar CHOMPING_KEEP  = 3;\n\n\nvar PATTERN_NON_PRINTABLE         = /[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7F-\\x84\\x86-\\x9F\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\nvar PATTERN_NON_ASCII_LINE_BREAKS = /[\\x85\\u2028\\u2029]/;\nvar PATTERN_FLOW_INDICATORS       = /[,\\[\\]\\{\\}]/;\nvar PATTERN_TAG_HANDLE            = /^(?:!|!!|![a-z\\-]+!)$/i;\nvar PATTERN_TAG_URI               = /^(?:!|[^,\\[\\]\\{\\}])(?:%[0-9a-f]{2}|[0-9a-z\\-#;\\/\\?:@&=\\+\\$,_\\.!~\\*'\\(\\)\\[\\]])*$/i;\n\n\nfunction is_EOL(c) {\n  return (c === 0x0A/* LF */) || (c === 0x0D/* CR */);\n}\n\nfunction is_WHITE_SPACE(c) {\n  return (c === 0x09/* Tab */) || (c === 0x20/* Space */);\n}\n\nfunction is_WS_OR_EOL(c) {\n  return (c === 0x09/* Tab */) ||\n         (c === 0x20/* Space */) ||\n         (c === 0x0A/* LF */) ||\n         (c === 0x0D/* CR */);\n}\n\nfunction is_FLOW_INDICATOR(c) {\n  return 0x2C/* , */ === c ||\n         0x5B/* [ */ === c ||\n         0x5D/* ] */ === c ||\n         0x7B/* { */ === c ||\n         0x7D/* } */ === c;\n}\n\nfunction fromHexCode(c) {\n  var lc;\n\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  /*eslint-disable no-bitwise*/\n  lc = c | 0x20;\n\n  if ((0x61/* a */ <= lc) && (lc <= 0x66/* f */)) {\n    return lc - 0x61 + 10;\n  }\n\n  return -1;\n}\n\nfunction escapedHexLen(c) {\n  if (c === 0x78/* x */) { return 2; }\n  if (c === 0x75/* u */) { return 4; }\n  if (c === 0x55/* U */) { return 8; }\n  return 0;\n}\n\nfunction fromDecimalCode(c) {\n  if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n    return c - 0x30;\n  }\n\n  return -1;\n}\n\nfunction simpleEscapeSequence(c) {\n  return (c === 0x30/* 0 */) ? '\\x00' :\n        (c === 0x61/* a */) ? '\\x07' :\n        (c === 0x62/* b */) ? '\\x08' :\n        (c === 0x74/* t */) ? '\\x09' :\n        (c === 0x09/* Tab */) ? '\\x09' :\n        (c === 0x6E/* n */) ? '\\x0A' :\n        (c === 0x76/* v */) ? '\\x0B' :\n        (c === 0x66/* f */) ? '\\x0C' :\n        (c === 0x72/* r */) ? '\\x0D' :\n        (c === 0x65/* e */) ? '\\x1B' :\n        (c === 0x20/* Space */) ? ' ' :\n        (c === 0x22/* \" */) ? '\\x22' :\n        (c === 0x2F/* / */) ? '/' :\n        (c === 0x5C/* \\ */) ? '\\x5C' :\n        (c === 0x4E/* N */) ? '\\x85' :\n        (c === 0x5F/* _ */) ? '\\xA0' :\n        (c === 0x4C/* L */) ? '\\u2028' :\n        (c === 0x50/* P */) ? '\\u2029' : '';\n}\n\nfunction charFromCodepoint(c) {\n  if (c <= 0xFFFF) {\n    return String.fromCharCode(c);\n  }\n  // Encode UTF-16 surrogate pair\n  // https://en.wikipedia.org/wiki/UTF-16#Code_points_U.2B010000_to_U.2B10FFFF\n  return String.fromCharCode(((c - 0x010000) >> 10) + 0xD800,\n                             ((c - 0x010000) & 0x03FF) + 0xDC00);\n}\n\nvar simpleEscapeCheck = new Array(256); // integer, for fast access\nvar simpleEscapeMap = new Array(256);\nfor (var i = 0; i < 256; i++) {\n  simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0;\n  simpleEscapeMap[i] = simpleEscapeSequence(i);\n}\n\n\nfunction State(input, options) {\n  this.input = input;\n\n  this.filename  = options['filename']  || null;\n  this.schema    = options['schema']    || DEFAULT_FULL_SCHEMA;\n  this.onWarning = options['onWarning'] || null;\n  this.legacy    = options['legacy']    || false;\n\n  this.implicitTypes = this.schema.compiledImplicit;\n  this.typeMap       = this.schema.compiledTypeMap;\n\n  this.length     = input.length;\n  this.position   = 0;\n  this.line       = 0;\n  this.lineStart  = 0;\n  this.lineIndent = 0;\n\n  this.documents = [];\n\n  /*\n  this.version;\n  this.checkLineBreaks;\n  this.tagMap;\n  this.anchorMap;\n  this.tag;\n  this.anchor;\n  this.kind;\n  this.result;*/\n\n}\n\n\nfunction generateError(state, message) {\n  return new YAMLException(\n    message,\n    new Mark(state.filename, state.input, state.position, state.line, (state.position - state.lineStart)));\n}\n\nfunction throwError(state, message) {\n  throw generateError(state, message);\n}\n\nfunction throwWarning(state, message) {\n  if (state.onWarning) {\n    state.onWarning.call(null, generateError(state, message));\n  }\n}\n\n\nvar directiveHandlers = {\n\n  YAML: function handleYamlDirective(state, name, args) {\n\n      var match, major, minor;\n\n      if (null !== state.version) {\n        throwError(state, 'duplication of %YAML directive');\n      }\n\n      if (1 !== args.length) {\n        throwError(state, 'YAML directive accepts exactly one argument');\n      }\n\n      match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n      if (null === match) {\n        throwError(state, 'ill-formed argument of the YAML directive');\n      }\n\n      major = parseInt(match[1], 10);\n      minor = parseInt(match[2], 10);\n\n      if (1 !== major) {\n        throwError(state, 'unacceptable YAML version of the document');\n      }\n\n      state.version = args[0];\n      state.checkLineBreaks = (minor < 2);\n\n      if (1 !== minor && 2 !== minor) {\n        throwWarning(state, 'unsupported YAML version of the document');\n      }\n    },\n\n  TAG: function handleTagDirective(state, name, args) {\n\n      var handle, prefix;\n\n      if (2 !== args.length) {\n        throwError(state, 'TAG directive accepts exactly two arguments');\n      }\n\n      handle = args[0];\n      prefix = args[1];\n\n      if (!PATTERN_TAG_HANDLE.test(handle)) {\n        throwError(state, 'ill-formed tag handle (first argument) of the TAG directive');\n      }\n\n      if (_hasOwnProperty.call(state.tagMap, handle)) {\n        throwError(state, 'there is a previously declared suffix for \"' + handle + '\" tag handle');\n      }\n\n      if (!PATTERN_TAG_URI.test(prefix)) {\n        throwError(state, 'ill-formed tag prefix (second argument) of the TAG directive');\n      }\n\n      state.tagMap[handle] = prefix;\n    }\n};\n\n\nfunction captureSegment(state, start, end, checkJson) {\n  var _position, _length, _character, _result;\n\n  if (start < end) {\n    _result = state.input.slice(start, end);\n\n    if (checkJson) {\n      for (_position = 0, _length = _result.length;\n           _position < _length;\n           _position += 1) {\n        _character = _result.charCodeAt(_position);\n        if (!(0x09 === _character ||\n              0x20 <= _character && _character <= 0x10FFFF)) {\n          throwError(state, 'expected valid JSON character');\n        }\n      }\n    } else if (PATTERN_NON_PRINTABLE.test(_result)) {\n      throwError(state, 'the stream contains non-printable characters');\n    }\n\n    state.result += _result;\n  }\n}\n\nfunction mergeMappings(state, destination, source) {\n  var sourceKeys, key, index, quantity;\n\n  if (!common.isObject(source)) {\n    throwError(state, 'cannot merge mappings; the provided source object is unacceptable');\n  }\n\n  sourceKeys = Object.keys(source);\n\n  for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) {\n    key = sourceKeys[index];\n\n    if (!_hasOwnProperty.call(destination, key)) {\n      destination[key] = source[key];\n    }\n  }\n}\n\nfunction storeMappingPair(state, _result, keyTag, keyNode, valueNode) {\n  var index, quantity;\n\n  keyNode = String(keyNode);\n\n  if (null === _result) {\n    _result = {};\n  }\n\n  if ('tag:yaml.org,2002:merge' === keyTag) {\n    if (Array.isArray(valueNode)) {\n      for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n        mergeMappings(state, _result, valueNode[index]);\n      }\n    } else {\n      mergeMappings(state, _result, valueNode);\n    }\n  } else {\n    _result[keyNode] = valueNode;\n  }\n\n  return _result;\n}\n\nfunction readLineBreak(state) {\n  var ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x0A/* LF */ === ch) {\n    state.position++;\n  } else if (0x0D/* CR */ === ch) {\n    state.position++;\n    if (0x0A/* LF */ === state.input.charCodeAt(state.position)) {\n      state.position++;\n    }\n  } else {\n    throwError(state, 'a line break is expected');\n  }\n\n  state.line += 1;\n  state.lineStart = state.position;\n}\n\nfunction skipSeparationSpace(state, allowComments, checkIndent) {\n  var lineBreaks = 0,\n      ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    while (is_WHITE_SPACE(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (allowComments && 0x23/* # */ === ch) {\n      do {\n        ch = state.input.charCodeAt(++state.position);\n      } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && 0 !== ch);\n    }\n\n    if (is_EOL(ch)) {\n      readLineBreak(state);\n\n      ch = state.input.charCodeAt(state.position);\n      lineBreaks++;\n      state.lineIndent = 0;\n\n      while (0x20/* Space */ === ch) {\n        state.lineIndent++;\n        ch = state.input.charCodeAt(++state.position);\n      }\n    } else {\n      break;\n    }\n  }\n\n  if (-1 !== checkIndent && 0 !== lineBreaks && state.lineIndent < checkIndent) {\n    throwWarning(state, 'deficient indentation');\n  }\n\n  return lineBreaks;\n}\n\nfunction testDocumentSeparator(state) {\n  var _position = state.position,\n      ch;\n\n  ch = state.input.charCodeAt(_position);\n\n  // Condition state.position === state.lineStart is tested\n  // in parent on each call, for efficiency. No needs to test here again.\n  if ((0x2D/* - */ === ch || 0x2E/* . */ === ch) &&\n      state.input.charCodeAt(_position + 1) === ch &&\n      state.input.charCodeAt(_position + 2) === ch) {\n\n    _position += 3;\n\n    ch = state.input.charCodeAt(_position);\n\n    if (ch === 0 || is_WS_OR_EOL(ch)) {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction writeFoldedLines(state, count) {\n  if (1 === count) {\n    state.result += ' ';\n  } else if (count > 1) {\n    state.result += common.repeat('\\n', count - 1);\n  }\n}\n\n\nfunction readPlainScalar(state, nodeIndent, withinFlowCollection) {\n  var preceding,\n      following,\n      captureStart,\n      captureEnd,\n      hasPendingContent,\n      _line,\n      _lineStart,\n      _lineIndent,\n      _kind = state.kind,\n      _result = state.result,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (is_WS_OR_EOL(ch)             ||\n      is_FLOW_INDICATOR(ch)        ||\n      0x23/* # */           === ch ||\n      0x26/* & */           === ch ||\n      0x2A/* * */           === ch ||\n      0x21/* ! */           === ch ||\n      0x7C/* | */           === ch ||\n      0x3E/* > */           === ch ||\n      0x27/* ' */           === ch ||\n      0x22/* \" */           === ch ||\n      0x25/* % */           === ch ||\n      0x40/* @ */           === ch ||\n      0x60/* ` */           === ch) {\n    return false;\n  }\n\n  if (0x3F/* ? */ === ch || 0x2D/* - */ === ch) {\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (is_WS_OR_EOL(following) ||\n        withinFlowCollection && is_FLOW_INDICATOR(following)) {\n      return false;\n    }\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  captureStart = captureEnd = state.position;\n  hasPendingContent = false;\n\n  while (0 !== ch) {\n    if (0x3A/* : */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following) ||\n          withinFlowCollection && is_FLOW_INDICATOR(following)) {\n        break;\n      }\n\n    } else if (0x23/* # */ === ch) {\n      preceding = state.input.charCodeAt(state.position - 1);\n\n      if (is_WS_OR_EOL(preceding)) {\n        break;\n      }\n\n    } else if ((state.position === state.lineStart && testDocumentSeparator(state)) ||\n               withinFlowCollection && is_FLOW_INDICATOR(ch)) {\n      break;\n\n    } else if (is_EOL(ch)) {\n      _line = state.line;\n      _lineStart = state.lineStart;\n      _lineIndent = state.lineIndent;\n      skipSeparationSpace(state, false, -1);\n\n      if (state.lineIndent >= nodeIndent) {\n        hasPendingContent = true;\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      } else {\n        state.position = captureEnd;\n        state.line = _line;\n        state.lineStart = _lineStart;\n        state.lineIndent = _lineIndent;\n        break;\n      }\n    }\n\n    if (hasPendingContent) {\n      captureSegment(state, captureStart, captureEnd, false);\n      writeFoldedLines(state, state.line - _line);\n      captureStart = captureEnd = state.position;\n      hasPendingContent = false;\n    }\n\n    if (!is_WHITE_SPACE(ch)) {\n      captureEnd = state.position + 1;\n    }\n\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  captureSegment(state, captureStart, captureEnd, false);\n\n  if (state.result) {\n    return true;\n  }\n\n  state.kind = _kind;\n  state.result = _result;\n  return false;\n}\n\nfunction readSingleQuotedScalar(state, nodeIndent) {\n  var ch,\n      captureStart, captureEnd;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x27/* ' */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x27/* ' */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (0x27/* ' */ === ch) {\n        captureStart = captureEnd = state.position;\n        state.position++;\n      } else {\n        return true;\n      }\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a single quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a single quoted scalar');\n}\n\nfunction readDoubleQuotedScalar(state, nodeIndent) {\n  var captureStart,\n      captureEnd,\n      hexLength,\n      hexResult,\n      tmp,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x22/* \" */ !== ch) {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n  state.position++;\n  captureStart = captureEnd = state.position;\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    if (0x22/* \" */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      state.position++;\n      return true;\n\n    } else if (0x5C/* \\ */ === ch) {\n      captureSegment(state, captureStart, state.position, true);\n      ch = state.input.charCodeAt(++state.position);\n\n      if (is_EOL(ch)) {\n        skipSeparationSpace(state, false, nodeIndent);\n\n        // TODO: rework to inline fn with no type cast?\n      } else if (ch < 256 && simpleEscapeCheck[ch]) {\n        state.result += simpleEscapeMap[ch];\n        state.position++;\n\n      } else if ((tmp = escapedHexLen(ch)) > 0) {\n        hexLength = tmp;\n        hexResult = 0;\n\n        for (; hexLength > 0; hexLength--) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if ((tmp = fromHexCode(ch)) >= 0) {\n            hexResult = (hexResult << 4) + tmp;\n\n          } else {\n            throwError(state, 'expected hexadecimal character');\n          }\n        }\n\n        state.result += charFromCodepoint(hexResult);\n\n        state.position++;\n\n      } else {\n        throwError(state, 'unknown escape sequence');\n      }\n\n      captureStart = captureEnd = state.position;\n\n    } else if (is_EOL(ch)) {\n      captureSegment(state, captureStart, captureEnd, true);\n      writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n      captureStart = captureEnd = state.position;\n\n    } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n      throwError(state, 'unexpected end of the document within a double quoted scalar');\n\n    } else {\n      state.position++;\n      captureEnd = state.position;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a double quoted scalar');\n}\n\nfunction readFlowCollection(state, nodeIndent) {\n  var readNext = true,\n      _line,\n      _tag     = state.tag,\n      _result,\n      _anchor  = state.anchor,\n      following,\n      terminator,\n      isPair,\n      isExplicitPair,\n      isMapping,\n      keyNode,\n      keyTag,\n      valueNode,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x5B/* [ */) {\n    terminator = 0x5D;/* ] */\n    isMapping = false;\n    _result = [];\n  } else if (ch === 0x7B/* { */) {\n    terminator = 0x7D;/* } */\n    isMapping = true;\n    _result = {};\n  } else {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  while (0 !== ch) {\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (ch === terminator) {\n      state.position++;\n      state.tag = _tag;\n      state.anchor = _anchor;\n      state.kind = isMapping ? 'mapping' : 'sequence';\n      state.result = _result;\n      return true;\n    } else if (!readNext) {\n      throwError(state, 'missed comma between flow collection entries');\n    }\n\n    keyTag = keyNode = valueNode = null;\n    isPair = isExplicitPair = false;\n\n    if (0x3F/* ? */ === ch) {\n      following = state.input.charCodeAt(state.position + 1);\n\n      if (is_WS_OR_EOL(following)) {\n        isPair = isExplicitPair = true;\n        state.position++;\n        skipSeparationSpace(state, true, nodeIndent);\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n    keyTag = state.tag;\n    keyNode = state.result;\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((isExplicitPair || state.line === _line) && 0x3A/* : */ === ch) {\n      isPair = true;\n      ch = state.input.charCodeAt(++state.position);\n      skipSeparationSpace(state, true, nodeIndent);\n      composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n      valueNode = state.result;\n    }\n\n    if (isMapping) {\n      storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n    } else if (isPair) {\n      _result.push(storeMappingPair(state, null, keyTag, keyNode, valueNode));\n    } else {\n      _result.push(keyNode);\n    }\n\n    skipSeparationSpace(state, true, nodeIndent);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (0x2C/* , */ === ch) {\n      readNext = true;\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      readNext = false;\n    }\n  }\n\n  throwError(state, 'unexpected end of the stream within a flow collection');\n}\n\nfunction readBlockScalar(state, nodeIndent) {\n  var captureStart,\n      folding,\n      chomping       = CHOMPING_CLIP,\n      detectedIndent = false,\n      textIndent     = nodeIndent,\n      emptyLines     = 0,\n      atMoreIndented = false,\n      tmp,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (ch === 0x7C/* | */) {\n    folding = false;\n  } else if (ch === 0x3E/* > */) {\n    folding = true;\n  } else {\n    return false;\n  }\n\n  state.kind = 'scalar';\n  state.result = '';\n\n  while (0 !== ch) {\n    ch = state.input.charCodeAt(++state.position);\n\n    if (0x2B/* + */ === ch || 0x2D/* - */ === ch) {\n      if (CHOMPING_CLIP === chomping) {\n        chomping = (0x2B/* + */ === ch) ? CHOMPING_KEEP : CHOMPING_STRIP;\n      } else {\n        throwError(state, 'repeat of a chomping mode identifier');\n      }\n\n    } else if ((tmp = fromDecimalCode(ch)) >= 0) {\n      if (tmp === 0) {\n        throwError(state, 'bad explicit indentation width of a block scalar; it cannot be less than one');\n      } else if (!detectedIndent) {\n        textIndent = nodeIndent + tmp - 1;\n        detectedIndent = true;\n      } else {\n        throwError(state, 'repeat of an indentation width identifier');\n      }\n\n    } else {\n      break;\n    }\n  }\n\n  if (is_WHITE_SPACE(ch)) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (is_WHITE_SPACE(ch));\n\n    if (0x23/* # */ === ch) {\n      do { ch = state.input.charCodeAt(++state.position); }\n      while (!is_EOL(ch) && (0 !== ch));\n    }\n  }\n\n  while (0 !== ch) {\n    readLineBreak(state);\n    state.lineIndent = 0;\n\n    ch = state.input.charCodeAt(state.position);\n\n    while ((!detectedIndent || state.lineIndent < textIndent) &&\n           (0x20/* Space */ === ch)) {\n      state.lineIndent++;\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    if (!detectedIndent && state.lineIndent > textIndent) {\n      textIndent = state.lineIndent;\n    }\n\n    if (is_EOL(ch)) {\n      emptyLines++;\n      continue;\n    }\n\n    // End of the scalar.\n    if (state.lineIndent < textIndent) {\n\n      // Perform the chomping.\n      if (chomping === CHOMPING_KEEP) {\n        state.result += common.repeat('\\n', emptyLines);\n      } else if (chomping === CHOMPING_CLIP) {\n        if (detectedIndent) { // i.e. only if the scalar is not empty.\n          state.result += '\\n';\n        }\n      }\n\n      // Break this `while` cycle and go to the funciton's epilogue.\n      break;\n    }\n\n    // Folded style: use fancy rules to handle line breaks.\n    if (folding) {\n\n      // Lines starting with white space characters (more-indented lines) are not folded.\n      if (is_WHITE_SPACE(ch)) {\n        atMoreIndented = true;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // End of more-indented block.\n      } else if (atMoreIndented) {\n        atMoreIndented = false;\n        state.result += common.repeat('\\n', emptyLines + 1);\n\n      // Just one line break - perceive as the same line.\n      } else if (0 === emptyLines) {\n        if (detectedIndent) { // i.e. only if we have already read some scalar content.\n          state.result += ' ';\n        }\n\n      // Several line breaks - perceive as different lines.\n      } else {\n        state.result += common.repeat('\\n', emptyLines);\n      }\n\n    // Literal style: just add exact number of line breaks between content lines.\n    } else if (detectedIndent) {\n      // If current line isn't the first one - count line break from the last content line.\n      state.result += common.repeat('\\n', emptyLines + 1);\n    } else {\n      // In case of the first content line - count only empty lines.\n      state.result += common.repeat('\\n', emptyLines);\n    }\n\n    detectedIndent = true;\n    emptyLines = 0;\n    captureStart = state.position;\n\n    while (!is_EOL(ch) && (0 !== ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    captureSegment(state, captureStart, state.position, false);\n  }\n\n  return true;\n}\n\nfunction readBlockSequence(state, nodeIndent) {\n  var _line,\n      _tag      = state.tag,\n      _anchor   = state.anchor,\n      _result   = [],\n      following,\n      detected  = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n\n    if (0x2D/* - */ !== ch) {\n      break;\n    }\n\n    following = state.input.charCodeAt(state.position + 1);\n\n    if (!is_WS_OR_EOL(following)) {\n      break;\n    }\n\n    detected = true;\n    state.position++;\n\n    if (skipSeparationSpace(state, true, -1)) {\n      if (state.lineIndent <= nodeIndent) {\n        _result.push(null);\n        ch = state.input.charCodeAt(state.position);\n        continue;\n      }\n    }\n\n    _line = state.line;\n    composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true);\n    _result.push(state.result);\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if ((state.line === _line || state.lineIndent > nodeIndent) && (0 !== ch)) {\n      throwError(state, 'bad indentation of a sequence entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'sequence';\n    state.result = _result;\n    return true;\n  }\n  return false;\n}\n\nfunction readBlockMapping(state, nodeIndent, flowIndent) {\n  var following,\n      allowCompact,\n      _line,\n      _tag          = state.tag,\n      _anchor       = state.anchor,\n      _result       = {},\n      keyTag        = null,\n      keyNode       = null,\n      valueNode     = null,\n      atExplicitKey = false,\n      detected      = false,\n      ch;\n\n  if (null !== state.anchor) {\n    state.anchorMap[state.anchor] = _result;\n  }\n\n  ch = state.input.charCodeAt(state.position);\n\n  while (0 !== ch) {\n    following = state.input.charCodeAt(state.position + 1);\n    _line = state.line; // Save the current line.\n\n    //\n    // Explicit notation case. There are two separate blocks:\n    // first for the key (denoted by \"?\") and second for the value (denoted by \":\")\n    //\n    if ((0x3F/* ? */ === ch || 0x3A/* : */  === ch) && is_WS_OR_EOL(following)) {\n\n      if (0x3F/* ? */ === ch) {\n        if (atExplicitKey) {\n          storeMappingPair(state, _result, keyTag, keyNode, null);\n          keyTag = keyNode = valueNode = null;\n        }\n\n        detected = true;\n        atExplicitKey = true;\n        allowCompact = true;\n\n      } else if (atExplicitKey) {\n        // i.e. 0x3A/* : */ === character after the explicit key.\n        atExplicitKey = false;\n        allowCompact = true;\n\n      } else {\n        throwError(state, 'incomplete explicit mapping pair; a key node is missed');\n      }\n\n      state.position += 1;\n      ch = following;\n\n    //\n    // Implicit notation case. Flow-style node as the key first, then \":\", and the value.\n    //\n    } else if (composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) {\n\n      if (state.line === _line) {\n        ch = state.input.charCodeAt(state.position);\n\n        while (is_WHITE_SPACE(ch)) {\n          ch = state.input.charCodeAt(++state.position);\n        }\n\n        if (0x3A/* : */ === ch) {\n          ch = state.input.charCodeAt(++state.position);\n\n          if (!is_WS_OR_EOL(ch)) {\n            throwError(state, 'a whitespace character is expected after the key-value separator within a block mapping');\n          }\n\n          if (atExplicitKey) {\n            storeMappingPair(state, _result, keyTag, keyNode, null);\n            keyTag = keyNode = valueNode = null;\n          }\n\n          detected = true;\n          atExplicitKey = false;\n          allowCompact = false;\n          keyTag = state.tag;\n          keyNode = state.result;\n\n        } else if (detected) {\n          throwError(state, 'can not read an implicit mapping pair; a colon is missed');\n\n        } else {\n          state.tag = _tag;\n          state.anchor = _anchor;\n          return true; // Keep the result of `composeNode`.\n        }\n\n      } else if (detected) {\n        throwError(state, 'can not read a block mapping entry; a multiline key may not be an implicit key');\n\n      } else {\n        state.tag = _tag;\n        state.anchor = _anchor;\n        return true; // Keep the result of `composeNode`.\n      }\n\n    } else {\n      break; // Reading is done. Go to the epilogue.\n    }\n\n    //\n    // Common reading code for both explicit and implicit notations.\n    //\n    if (state.line === _line || state.lineIndent > nodeIndent) {\n      if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) {\n        if (atExplicitKey) {\n          keyNode = state.result;\n        } else {\n          valueNode = state.result;\n        }\n      }\n\n      if (!atExplicitKey) {\n        storeMappingPair(state, _result, keyTag, keyNode, valueNode);\n        keyTag = keyNode = valueNode = null;\n      }\n\n      skipSeparationSpace(state, true, -1);\n      ch = state.input.charCodeAt(state.position);\n    }\n\n    if (state.lineIndent > nodeIndent && (0 !== ch)) {\n      throwError(state, 'bad indentation of a mapping entry');\n    } else if (state.lineIndent < nodeIndent) {\n      break;\n    }\n  }\n\n  //\n  // Epilogue.\n  //\n\n  // Special case: last mapping's node contains only the key in explicit notation.\n  if (atExplicitKey) {\n    storeMappingPair(state, _result, keyTag, keyNode, null);\n  }\n\n  // Expose the resulting mapping.\n  if (detected) {\n    state.tag = _tag;\n    state.anchor = _anchor;\n    state.kind = 'mapping';\n    state.result = _result;\n  }\n\n  return detected;\n}\n\nfunction readTagProperty(state) {\n  var _position,\n      isVerbatim = false,\n      isNamed    = false,\n      tagHandle,\n      tagName,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x21/* ! */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.tag) {\n    throwError(state, 'duplication of a tag property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n\n  if (0x3C/* < */ === ch) {\n    isVerbatim = true;\n    ch = state.input.charCodeAt(++state.position);\n\n  } else if (0x21/* ! */ === ch) {\n    isNamed = true;\n    tagHandle = '!!';\n    ch = state.input.charCodeAt(++state.position);\n\n  } else {\n    tagHandle = '!';\n  }\n\n  _position = state.position;\n\n  if (isVerbatim) {\n    do { ch = state.input.charCodeAt(++state.position); }\n    while (0 !== ch && 0x3E/* > */ !== ch);\n\n    if (state.position < state.length) {\n      tagName = state.input.slice(_position, state.position);\n      ch = state.input.charCodeAt(++state.position);\n    } else {\n      throwError(state, 'unexpected end of the stream within a verbatim tag');\n    }\n  } else {\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n\n      if (0x21/* ! */ === ch) {\n        if (!isNamed) {\n          tagHandle = state.input.slice(_position - 1, state.position + 1);\n\n          if (!PATTERN_TAG_HANDLE.test(tagHandle)) {\n            throwError(state, 'named tag handle cannot contain such characters');\n          }\n\n          isNamed = true;\n          _position = state.position + 1;\n        } else {\n          throwError(state, 'tag suffix cannot contain exclamation marks');\n        }\n      }\n\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    tagName = state.input.slice(_position, state.position);\n\n    if (PATTERN_FLOW_INDICATORS.test(tagName)) {\n      throwError(state, 'tag suffix cannot contain flow indicator characters');\n    }\n  }\n\n  if (tagName && !PATTERN_TAG_URI.test(tagName)) {\n    throwError(state, 'tag name cannot contain such characters: ' + tagName);\n  }\n\n  if (isVerbatim) {\n    state.tag = tagName;\n\n  } else if (_hasOwnProperty.call(state.tagMap, tagHandle)) {\n    state.tag = state.tagMap[tagHandle] + tagName;\n\n  } else if ('!' === tagHandle) {\n    state.tag = '!' + tagName;\n\n  } else if ('!!' === tagHandle) {\n    state.tag = 'tag:yaml.org,2002:' + tagName;\n\n  } else {\n    throwError(state, 'undeclared tag handle \"' + tagHandle + '\"');\n  }\n\n  return true;\n}\n\nfunction readAnchorProperty(state) {\n  var _position,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x26/* & */ !== ch) {\n    return false;\n  }\n\n  if (null !== state.anchor) {\n    throwError(state, 'duplication of an anchor property');\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an anchor node must contain at least one character');\n  }\n\n  state.anchor = state.input.slice(_position, state.position);\n  return true;\n}\n\nfunction readAlias(state) {\n  var _position, alias,\n      ch;\n\n  ch = state.input.charCodeAt(state.position);\n\n  if (0x2A/* * */ !== ch) {\n    return false;\n  }\n\n  ch = state.input.charCodeAt(++state.position);\n  _position = state.position;\n\n  while (0 !== ch && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n    ch = state.input.charCodeAt(++state.position);\n  }\n\n  if (state.position === _position) {\n    throwError(state, 'name of an alias node must contain at least one character');\n  }\n\n  alias = state.input.slice(_position, state.position);\n\n  if (!state.anchorMap.hasOwnProperty(alias)) {\n    throwError(state, 'unidentified alias \"' + alias + '\"');\n  }\n\n  state.result = state.anchorMap[alias];\n  skipSeparationSpace(state, true, -1);\n  return true;\n}\n\nfunction composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) {\n  var allowBlockStyles,\n      allowBlockScalars,\n      allowBlockCollections,\n      indentStatus = 1, // 1: this>parent, 0: this=parent, -1: this<parent\n      atNewLine  = false,\n      hasContent = false,\n      typeIndex,\n      typeQuantity,\n      type,\n      flowIndent,\n      blockIndent;\n\n  state.tag    = null;\n  state.anchor = null;\n  state.kind   = null;\n  state.result = null;\n\n  allowBlockStyles = allowBlockScalars = allowBlockCollections =\n    CONTEXT_BLOCK_OUT === nodeContext ||\n    CONTEXT_BLOCK_IN  === nodeContext;\n\n  if (allowToSeek) {\n    if (skipSeparationSpace(state, true, -1)) {\n      atNewLine = true;\n\n      if (state.lineIndent > parentIndent) {\n        indentStatus = 1;\n      } else if (state.lineIndent === parentIndent) {\n        indentStatus = 0;\n      } else if (state.lineIndent < parentIndent) {\n        indentStatus = -1;\n      }\n    }\n  }\n\n  if (1 === indentStatus) {\n    while (readTagProperty(state) || readAnchorProperty(state)) {\n      if (skipSeparationSpace(state, true, -1)) {\n        atNewLine = true;\n        allowBlockCollections = allowBlockStyles;\n\n        if (state.lineIndent > parentIndent) {\n          indentStatus = 1;\n        } else if (state.lineIndent === parentIndent) {\n          indentStatus = 0;\n        } else if (state.lineIndent < parentIndent) {\n          indentStatus = -1;\n        }\n      } else {\n        allowBlockCollections = false;\n      }\n    }\n  }\n\n  if (allowBlockCollections) {\n    allowBlockCollections = atNewLine || allowCompact;\n  }\n\n  if (1 === indentStatus || CONTEXT_BLOCK_OUT === nodeContext) {\n    if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) {\n      flowIndent = parentIndent;\n    } else {\n      flowIndent = parentIndent + 1;\n    }\n\n    blockIndent = state.position - state.lineStart;\n\n    if (1 === indentStatus) {\n      if (allowBlockCollections &&\n          (readBlockSequence(state, blockIndent) ||\n           readBlockMapping(state, blockIndent, flowIndent)) ||\n          readFlowCollection(state, flowIndent)) {\n        hasContent = true;\n      } else {\n        if ((allowBlockScalars && readBlockScalar(state, flowIndent)) ||\n            readSingleQuotedScalar(state, flowIndent) ||\n            readDoubleQuotedScalar(state, flowIndent)) {\n          hasContent = true;\n\n        } else if (readAlias(state)) {\n          hasContent = true;\n\n          if (null !== state.tag || null !== state.anchor) {\n            throwError(state, 'alias node should not have any properties');\n          }\n\n        } else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) {\n          hasContent = true;\n\n          if (null === state.tag) {\n            state.tag = '?';\n          }\n        }\n\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else if (0 === indentStatus) {\n      // Special case: block sequences are allowed to have same indentation level as the parent.\n      // http://www.yaml.org/spec/1.2/spec.html#id2799784\n      hasContent = allowBlockCollections && readBlockSequence(state, blockIndent);\n    }\n  }\n\n  if (null !== state.tag && '!' !== state.tag) {\n    if ('?' === state.tag) {\n      for (typeIndex = 0, typeQuantity = state.implicitTypes.length;\n           typeIndex < typeQuantity;\n           typeIndex += 1) {\n        type = state.implicitTypes[typeIndex];\n\n        // Implicit resolving is not allowed for non-scalar types, and '?'\n        // non-specific tag is only assigned to plain scalars. So, it isn't\n        // needed to check for 'kind' conformity.\n\n        if (type.resolve(state.result)) { // `state.result` updated in resolver if matched\n          state.result = type.construct(state.result);\n          state.tag = type.tag;\n          if (null !== state.anchor) {\n            state.anchorMap[state.anchor] = state.result;\n          }\n          break;\n        }\n      }\n    } else if (_hasOwnProperty.call(state.typeMap, state.tag)) {\n      type = state.typeMap[state.tag];\n\n      if (null !== state.result && type.kind !== state.kind) {\n        throwError(state, 'unacceptable node kind for !<' + state.tag + '> tag; it should be \"' + type.kind + '\", not \"' + state.kind + '\"');\n      }\n\n      if (!type.resolve(state.result)) { // `state.result` updated in resolver if matched\n        throwError(state, 'cannot resolve a node with !<' + state.tag + '> explicit tag');\n      } else {\n        state.result = type.construct(state.result);\n        if (null !== state.anchor) {\n          state.anchorMap[state.anchor] = state.result;\n        }\n      }\n    } else {\n      throwError(state, 'unknown tag !<' + state.tag + '>');\n    }\n  }\n\n  return null !== state.tag || null !== state.anchor || hasContent;\n}\n\nfunction readDocument(state) {\n  var documentStart = state.position,\n      _position,\n      directiveName,\n      directiveArgs,\n      hasDirectives = false,\n      ch;\n\n  state.version = null;\n  state.checkLineBreaks = state.legacy;\n  state.tagMap = {};\n  state.anchorMap = {};\n\n  while (0 !== (ch = state.input.charCodeAt(state.position))) {\n    skipSeparationSpace(state, true, -1);\n\n    ch = state.input.charCodeAt(state.position);\n\n    if (state.lineIndent > 0 || 0x25/* % */ !== ch) {\n      break;\n    }\n\n    hasDirectives = true;\n    ch = state.input.charCodeAt(++state.position);\n    _position = state.position;\n\n    while (0 !== ch && !is_WS_OR_EOL(ch)) {\n      ch = state.input.charCodeAt(++state.position);\n    }\n\n    directiveName = state.input.slice(_position, state.position);\n    directiveArgs = [];\n\n    if (directiveName.length < 1) {\n      throwError(state, 'directive name must not be less than one character in length');\n    }\n\n    while (0 !== ch) {\n      while (is_WHITE_SPACE(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      if (0x23/* # */ === ch) {\n        do { ch = state.input.charCodeAt(++state.position); }\n        while (0 !== ch && !is_EOL(ch));\n        break;\n      }\n\n      if (is_EOL(ch)) {\n        break;\n      }\n\n      _position = state.position;\n\n      while (0 !== ch && !is_WS_OR_EOL(ch)) {\n        ch = state.input.charCodeAt(++state.position);\n      }\n\n      directiveArgs.push(state.input.slice(_position, state.position));\n    }\n\n    if (0 !== ch) {\n      readLineBreak(state);\n    }\n\n    if (_hasOwnProperty.call(directiveHandlers, directiveName)) {\n      directiveHandlers[directiveName](state, directiveName, directiveArgs);\n    } else {\n      throwWarning(state, 'unknown document directive \"' + directiveName + '\"');\n    }\n  }\n\n  skipSeparationSpace(state, true, -1);\n\n  if (0 === state.lineIndent &&\n      0x2D/* - */ === state.input.charCodeAt(state.position) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 1) &&\n      0x2D/* - */ === state.input.charCodeAt(state.position + 2)) {\n    state.position += 3;\n    skipSeparationSpace(state, true, -1);\n\n  } else if (hasDirectives) {\n    throwError(state, 'directives end mark is expected');\n  }\n\n  composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true);\n  skipSeparationSpace(state, true, -1);\n\n  if (state.checkLineBreaks &&\n      PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) {\n    throwWarning(state, 'non-ASCII line breaks are interpreted as content');\n  }\n\n  state.documents.push(state.result);\n\n  if (state.position === state.lineStart && testDocumentSeparator(state)) {\n\n    if (0x2E/* . */ === state.input.charCodeAt(state.position)) {\n      state.position += 3;\n      skipSeparationSpace(state, true, -1);\n    }\n    return;\n  }\n\n  if (state.position < (state.length - 1)) {\n    throwError(state, 'end of the stream or a document separator is expected');\n  } else {\n    return;\n  }\n}\n\n\nfunction loadDocuments(input, options) {\n  input = String(input);\n  options = options || {};\n\n  if (input.length !== 0) {\n\n    // Add tailing `\\n` if not exists\n    if (0x0A/* LF */ !== input.charCodeAt(input.length - 1) &&\n        0x0D/* CR */ !== input.charCodeAt(input.length - 1)) {\n      input += '\\n';\n    }\n\n    // Strip BOM\n    if (input.charCodeAt(0) === 0xFEFF) {\n      input = input.slice(1);\n    }\n  }\n\n  var state = new State(input, options);\n\n  // Use 0 as string terminator. That significantly simplifies bounds check.\n  state.input += '\\0';\n\n  while (0x20/* Space */ === state.input.charCodeAt(state.position)) {\n    state.lineIndent += 1;\n    state.position += 1;\n  }\n\n  while (state.position < (state.length - 1)) {\n    readDocument(state);\n  }\n\n  return state.documents;\n}\n\n\nfunction loadAll(input, iterator, options) {\n  var documents = loadDocuments(input, options), index, length;\n\n  for (index = 0, length = documents.length; index < length; index += 1) {\n    iterator(documents[index]);\n  }\n}\n\n\nfunction load(input, options) {\n  var documents = loadDocuments(input, options);\n\n  if (0 === documents.length) {\n    /*eslint-disable no-undefined*/\n    return undefined;\n  } else if (1 === documents.length) {\n    return documents[0];\n  }\n  throw new YAMLException('expected a single document in the stream, but found more');\n}\n\n\nfunction safeLoadAll(input, output, options) {\n  loadAll(input, output, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nfunction safeLoad(input, options) {\n  return load(input, common.extend({ schema: DEFAULT_SAFE_SCHEMA }, options));\n}\n\n\nmodule.exports.loadAll     = loadAll;\nmodule.exports.load        = load;\nmodule.exports.safeLoadAll = safeLoadAll;\nmodule.exports.safeLoad    = safeLoad;\n","'use strict';\n\n\nvar common = require('./common');\n\n\nfunction Mark(name, buffer, position, line, column) {\n  this.name     = name;\n  this.buffer   = buffer;\n  this.position = position;\n  this.line     = line;\n  this.column   = column;\n}\n\n\nMark.prototype.getSnippet = function getSnippet(indent, maxLength) {\n  var head, start, tail, end, snippet;\n\n  if (!this.buffer) {\n    return null;\n  }\n\n  indent = indent || 4;\n  maxLength = maxLength || 75;\n\n  head = '';\n  start = this.position;\n\n  while (start > 0 && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(start - 1))) {\n    start -= 1;\n    if (this.position - start > (maxLength / 2 - 1)) {\n      head = ' ... ';\n      start += 5;\n      break;\n    }\n  }\n\n  tail = '';\n  end = this.position;\n\n  while (end < this.buffer.length && -1 === '\\x00\\r\\n\\x85\\u2028\\u2029'.indexOf(this.buffer.charAt(end))) {\n    end += 1;\n    if (end - this.position > (maxLength / 2 - 1)) {\n      tail = ' ... ';\n      end -= 5;\n      break;\n    }\n  }\n\n  snippet = this.buffer.slice(start, end);\n\n  return common.repeat(' ', indent) + head + snippet + tail + '\\n' +\n         common.repeat(' ', indent + this.position - start + head.length) + '^';\n};\n\n\nMark.prototype.toString = function toString(compact) {\n  var snippet, where = '';\n\n  if (this.name) {\n    where += 'in \"' + this.name + '\" ';\n  }\n\n  where += 'at line ' + (this.line + 1) + ', column ' + (this.column + 1);\n\n  if (!compact) {\n    snippet = this.getSnippet();\n\n    if (snippet) {\n      where += ':\\n' + snippet;\n    }\n  }\n\n  return where;\n};\n\n\nmodule.exports = Mark;\n","'use strict';\n\n/*eslint-disable max-len*/\n\nvar common        = require('./common');\nvar YAMLException = require('./exception');\nvar Type          = require('./type');\n\n\nfunction compileList(schema, name, result) {\n  var exclude = [];\n\n  schema.include.forEach(function (includedSchema) {\n    result = compileList(includedSchema, name, result);\n  });\n\n  schema[name].forEach(function (currentType) {\n    result.forEach(function (previousType, previousIndex) {\n      if (previousType.tag === currentType.tag) {\n        exclude.push(previousIndex);\n      }\n    });\n\n    result.push(currentType);\n  });\n\n  return result.filter(function (type, index) {\n    return -1 === exclude.indexOf(index);\n  });\n}\n\n\nfunction compileMap(/* lists... */) {\n  var result = {}, index, length;\n\n  function collectType(type) {\n    result[type.tag] = type;\n  }\n\n  for (index = 0, length = arguments.length; index < length; index += 1) {\n    arguments[index].forEach(collectType);\n  }\n\n  return result;\n}\n\n\nfunction Schema(definition) {\n  this.include  = definition.include  || [];\n  this.implicit = definition.implicit || [];\n  this.explicit = definition.explicit || [];\n\n  this.implicit.forEach(function (type) {\n    if (type.loadKind && 'scalar' !== type.loadKind) {\n      throw new YAMLException('There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.');\n    }\n  });\n\n  this.compiledImplicit = compileList(this, 'implicit', []);\n  this.compiledExplicit = compileList(this, 'explicit', []);\n  this.compiledTypeMap  = compileMap(this.compiledImplicit, this.compiledExplicit);\n}\n\n\nSchema.DEFAULT = null;\n\n\nSchema.create = function createSchema() {\n  var schemas, types;\n\n  switch (arguments.length) {\n  case 1:\n    schemas = Schema.DEFAULT;\n    types = arguments[0];\n    break;\n\n  case 2:\n    schemas = arguments[0];\n    types = arguments[1];\n    break;\n\n  default:\n    throw new YAMLException('Wrong number of arguments for Schema.create function');\n  }\n\n  schemas = common.toArray(schemas);\n  types = common.toArray(types);\n\n  if (!schemas.every(function (schema) { return schema instanceof Schema; })) {\n    throw new YAMLException('Specified list of super schemas (or a single Schema object) contains a non-Schema object.');\n  }\n\n  if (!types.every(function (type) { return type instanceof Type; })) {\n    throw new YAMLException('Specified list of YAML types (or a single Type object) contains a non-Type object.');\n  }\n\n  return new Schema({\n    include: schemas,\n    explicit: types\n  });\n};\n\n\nmodule.exports = Schema;\n","// Standard YAML's Core schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2804923\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, Core schema has no distinctions from JSON schema is JS-YAML.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./json')\n  ]\n});\n","// JS-YAML's default schema for `load` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on JS-YAML's default safe schema and includes\n// JavaScript-specific types: !!js/undefined, !!js/regexp and !!js/function.\n//\n// Also this schema is used as default base schema at `Schema.create` function.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = Schema.DEFAULT = new Schema({\n  include: [\n    require('./default_safe')\n  ],\n  explicit: [\n    require('../type/js/undefined'),\n    require('../type/js/regexp'),\n    require('../type/js/function')\n  ]\n});\n","// JS-YAML's default schema for `safeLoad` function.\n// It is not described in the YAML specification.\n//\n// This schema is based on standard YAML's Core schema and includes most of\n// extra types described at YAML tag repository. (http://yaml.org/type/)\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./core')\n  ],\n  implicit: [\n    require('../type/timestamp'),\n    require('../type/merge')\n  ],\n  explicit: [\n    require('../type/binary'),\n    require('../type/omap'),\n    require('../type/pairs'),\n    require('../type/set')\n  ]\n});\n","// Standard YAML's Failsafe schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2802346\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  explicit: [\n    require('../type/str'),\n    require('../type/seq'),\n    require('../type/map')\n  ]\n});\n","// Standard YAML's JSON schema.\n// http://www.yaml.org/spec/1.2/spec.html#id2803231\n//\n// NOTE: JS-YAML does not support schema-specific tag resolution restrictions.\n// So, this schema is not such strict as defined in the YAML specification.\n// It allows numbers in binary notaion, use `Null` and `NULL` as `null`, etc.\n\n\n'use strict';\n\n\nvar Schema = require('../schema');\n\n\nmodule.exports = new Schema({\n  include: [\n    require('./failsafe')\n  ],\n  implicit: [\n    require('../type/null'),\n    require('../type/bool'),\n    require('../type/int'),\n    require('../type/float')\n  ]\n});\n","'use strict';\n\nvar YAMLException = require('./exception');\n\nvar TYPE_CONSTRUCTOR_OPTIONS = [\n  'kind',\n  'resolve',\n  'construct',\n  'instanceOf',\n  'predicate',\n  'represent',\n  'defaultStyle',\n  'styleAliases'\n];\n\nvar YAML_NODE_KINDS = [\n  'scalar',\n  'sequence',\n  'mapping'\n];\n\nfunction compileStyleAliases(map) {\n  var result = {};\n\n  if (null !== map) {\n    Object.keys(map).forEach(function (style) {\n      map[style].forEach(function (alias) {\n        result[String(alias)] = style;\n      });\n    });\n  }\n\n  return result;\n}\n\nfunction Type(tag, options) {\n  options = options || {};\n\n  Object.keys(options).forEach(function (name) {\n    if (-1 === TYPE_CONSTRUCTOR_OPTIONS.indexOf(name)) {\n      throw new YAMLException('Unknown option \"' + name + '\" is met in definition of \"' + tag + '\" YAML type.');\n    }\n  });\n\n  // TODO: Add tag format check.\n  this.tag          = tag;\n  this.kind         = options['kind']         || null;\n  this.resolve      = options['resolve']      || function () { return true; };\n  this.construct    = options['construct']    || function (data) { return data; };\n  this.instanceOf   = options['instanceOf']   || null;\n  this.predicate    = options['predicate']    || null;\n  this.represent    = options['represent']    || null;\n  this.defaultStyle = options['defaultStyle'] || null;\n  this.styleAliases = compileStyleAliases(options['styleAliases'] || null);\n\n  if (-1 === YAML_NODE_KINDS.indexOf(this.kind)) {\n    throw new YAMLException('Unknown kind \"' + this.kind + '\" is specified for \"' + tag + '\" YAML type.');\n  }\n}\n\nmodule.exports = Type;\n","'use strict';\n\n/*eslint-disable no-bitwise*/\n\n// A trick for browserified version.\n// Since we make browserifier to ignore `buffer` module, NodeBuffer will be undefined\nvar NodeBuffer = require('buffer').Buffer;\nvar Type       = require('../type');\n\n\n// [ 64, 65, 66 ] -> [ padding, CR, LF ]\nvar BASE64_MAP = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\\n\\r';\n\n\nfunction resolveYamlBinary(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var code, idx, bitlen = 0, max = data.length, map = BASE64_MAP;\n\n  // Convert one by one.\n  for (idx = 0; idx < max; idx++) {\n    code = map.indexOf(data.charAt(idx));\n\n    // Skip CR/LF\n    if (code > 64) { continue; }\n\n    // Fail on illegal characters\n    if (code < 0) { return false; }\n\n    bitlen += 6;\n  }\n\n  // If there are any bits left, source was corrupted\n  return (bitlen % 8) === 0;\n}\n\nfunction constructYamlBinary(data) {\n  var idx, tailbits,\n      input = data.replace(/[\\r\\n=]/g, ''), // remove CR/LF & padding to simplify scan\n      max = input.length,\n      map = BASE64_MAP,\n      bits = 0,\n      result = [];\n\n  // Collect by 6*4 bits (3 bytes)\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 4 === 0) && idx) {\n      result.push((bits >> 16) & 0xFF);\n      result.push((bits >> 8) & 0xFF);\n      result.push(bits & 0xFF);\n    }\n\n    bits = (bits << 6) | map.indexOf(input.charAt(idx));\n  }\n\n  // Dump tail\n\n  tailbits = (max % 4) * 6;\n\n  if (tailbits === 0) {\n    result.push((bits >> 16) & 0xFF);\n    result.push((bits >> 8) & 0xFF);\n    result.push(bits & 0xFF);\n  } else if (tailbits === 18) {\n    result.push((bits >> 10) & 0xFF);\n    result.push((bits >> 2) & 0xFF);\n  } else if (tailbits === 12) {\n    result.push((bits >> 4) & 0xFF);\n  }\n\n  // Wrap into Buffer for NodeJS and leave Array for browser\n  if (NodeBuffer) {\n    return new NodeBuffer(result);\n  }\n\n  return result;\n}\n\nfunction representYamlBinary(object /*, style*/) {\n  var result = '', bits = 0, idx, tail,\n      max = object.length,\n      map = BASE64_MAP;\n\n  // Convert every three bytes to 4 ASCII characters.\n\n  for (idx = 0; idx < max; idx++) {\n    if ((idx % 3 === 0) && idx) {\n      result += map[(bits >> 18) & 0x3F];\n      result += map[(bits >> 12) & 0x3F];\n      result += map[(bits >> 6) & 0x3F];\n      result += map[bits & 0x3F];\n    }\n\n    bits = (bits << 8) + object[idx];\n  }\n\n  // Dump tail\n\n  tail = max % 3;\n\n  if (tail === 0) {\n    result += map[(bits >> 18) & 0x3F];\n    result += map[(bits >> 12) & 0x3F];\n    result += map[(bits >> 6) & 0x3F];\n    result += map[bits & 0x3F];\n  } else if (tail === 2) {\n    result += map[(bits >> 10) & 0x3F];\n    result += map[(bits >> 4) & 0x3F];\n    result += map[(bits << 2) & 0x3F];\n    result += map[64];\n  } else if (tail === 1) {\n    result += map[(bits >> 2) & 0x3F];\n    result += map[(bits << 4) & 0x3F];\n    result += map[64];\n    result += map[64];\n  }\n\n  return result;\n}\n\nfunction isBinary(object) {\n  return NodeBuffer && NodeBuffer.isBuffer(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:binary', {\n  kind: 'scalar',\n  resolve: resolveYamlBinary,\n  construct: constructYamlBinary,\n  predicate: isBinary,\n  represent: representYamlBinary\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlBoolean(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length;\n\n  return (max === 4 && (data === 'true' || data === 'True' || data === 'TRUE')) ||\n         (max === 5 && (data === 'false' || data === 'False' || data === 'FALSE'));\n}\n\nfunction constructYamlBoolean(data) {\n  return data === 'true' ||\n         data === 'True' ||\n         data === 'TRUE';\n}\n\nfunction isBoolean(object) {\n  return '[object Boolean]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:bool', {\n  kind: 'scalar',\n  resolve: resolveYamlBoolean,\n  construct: constructYamlBoolean,\n  predicate: isBoolean,\n  represent: {\n    lowercase: function (object) { return object ? 'true' : 'false'; },\n    uppercase: function (object) { return object ? 'TRUE' : 'FALSE'; },\n    camelcase: function (object) { return object ? 'True' : 'False'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nvar YAML_FLOAT_PATTERN = new RegExp(\n  '^(?:[-+]?(?:[0-9][0-9_]*)\\\\.[0-9_]*(?:[eE][-+][0-9]+)?' +\n  '|\\\\.[0-9_]+(?:[eE][-+][0-9]+)?' +\n  '|[-+]?[0-9][0-9_]*(?::[0-5]?[0-9])+\\\\.[0-9_]*' +\n  '|[-+]?\\\\.(?:inf|Inf|INF)' +\n  '|\\\\.(?:nan|NaN|NAN))$');\n\nfunction resolveYamlFloat(data) {\n  if (null === data) {\n    return false;\n  }\n\n  if (!YAML_FLOAT_PATTERN.test(data)) {\n    return false;\n  }\n  return true;\n}\n\nfunction constructYamlFloat(data) {\n  var value, sign, base, digits;\n\n  value  = data.replace(/_/g, '').toLowerCase();\n  sign   = '-' === value[0] ? -1 : 1;\n  digits = [];\n\n  if (0 <= '+-'.indexOf(value[0])) {\n    value = value.slice(1);\n  }\n\n  if ('.inf' === value) {\n    return (1 === sign) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n  } else if ('.nan' === value) {\n    return NaN;\n\n  } else if (0 <= value.indexOf(':')) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseFloat(v, 10));\n    });\n\n    value = 0.0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += d * base;\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n  return sign * parseFloat(value, 10);\n}\n\n\nvar SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/;\n\nfunction representYamlFloat(object, style) {\n  var res;\n\n  if (isNaN(object)) {\n    switch (style) {\n    case 'lowercase':\n      return '.nan';\n    case 'uppercase':\n      return '.NAN';\n    case 'camelcase':\n      return '.NaN';\n    }\n  } else if (Number.POSITIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '.inf';\n    case 'uppercase':\n      return '.INF';\n    case 'camelcase':\n      return '.Inf';\n    }\n  } else if (Number.NEGATIVE_INFINITY === object) {\n    switch (style) {\n    case 'lowercase':\n      return '-.inf';\n    case 'uppercase':\n      return '-.INF';\n    case 'camelcase':\n      return '-.Inf';\n    }\n  } else if (common.isNegativeZero(object)) {\n    return '-0.0';\n  }\n\n  res = object.toString(10);\n\n  // JS stringifier can build scientific format without dots: 5e-100,\n  // while YAML requres dot: 5.e-100. Fix it with simple hack\n\n  return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace('e', '.e') : res;\n}\n\nfunction isFloat(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 !== object % 1 || common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:float', {\n  kind: 'scalar',\n  resolve: resolveYamlFloat,\n  construct: constructYamlFloat,\n  predicate: isFloat,\n  represent: representYamlFloat,\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar common = require('../common');\nvar Type   = require('../type');\n\nfunction isHexCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||\n         ((0x41/* A */ <= c) && (c <= 0x46/* F */)) ||\n         ((0x61/* a */ <= c) && (c <= 0x66/* f */));\n}\n\nfunction isOctCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x37/* 7 */));\n}\n\nfunction isDecCode(c) {\n  return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */));\n}\n\nfunction resolveYamlInteger(data) {\n  if (null === data) {\n    return false;\n  }\n\n  var max = data.length,\n      index = 0,\n      hasDigits = false,\n      ch;\n\n  if (!max) { return false; }\n\n  ch = data[index];\n\n  // sign\n  if (ch === '-' || ch === '+') {\n    ch = data[++index];\n  }\n\n  if (ch === '0') {\n    // 0\n    if (index + 1 === max) { return true; }\n    ch = data[++index];\n\n    // base 2, base 8, base 16\n\n    if (ch === 'b') {\n      // base 2\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (ch !== '0' && ch !== '1') {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n\n    if (ch === 'x') {\n      // base 16\n      index++;\n\n      for (; index < max; index++) {\n        ch = data[index];\n        if (ch === '_') { continue; }\n        if (!isHexCode(data.charCodeAt(index))) {\n          return false;\n        }\n        hasDigits = true;\n      }\n      return hasDigits;\n    }\n\n    // base 8\n    for (; index < max; index++) {\n      ch = data[index];\n      if (ch === '_') { continue; }\n      if (!isOctCode(data.charCodeAt(index))) {\n        return false;\n      }\n      hasDigits = true;\n    }\n    return hasDigits;\n  }\n\n  // base 10 (except 0) or base 60\n\n  for (; index < max; index++) {\n    ch = data[index];\n    if (ch === '_') { continue; }\n    if (ch === ':') { break; }\n    if (!isDecCode(data.charCodeAt(index))) {\n      return false;\n    }\n    hasDigits = true;\n  }\n\n  if (!hasDigits) { return false; }\n\n  // if !base60 - done;\n  if (ch !== ':') { return true; }\n\n  // base60 almost not used, no needs to optimize\n  return /^(:[0-5]?[0-9])+$/.test(data.slice(index));\n}\n\nfunction constructYamlInteger(data) {\n  var value = data, sign = 1, ch, base, digits = [];\n\n  if (value.indexOf('_') !== -1) {\n    value = value.replace(/_/g, '');\n  }\n\n  ch = value[0];\n\n  if (ch === '-' || ch === '+') {\n    if (ch === '-') { sign = -1; }\n    value = value.slice(1);\n    ch = value[0];\n  }\n\n  if ('0' === value) {\n    return 0;\n  }\n\n  if (ch === '0') {\n    if (value[1] === 'b') {\n      return sign * parseInt(value.slice(2), 2);\n    }\n    if (value[1] === 'x') {\n      return sign * parseInt(value, 16);\n    }\n    return sign * parseInt(value, 8);\n\n  }\n\n  if (value.indexOf(':') !== -1) {\n    value.split(':').forEach(function (v) {\n      digits.unshift(parseInt(v, 10));\n    });\n\n    value = 0;\n    base = 1;\n\n    digits.forEach(function (d) {\n      value += (d * base);\n      base *= 60;\n    });\n\n    return sign * value;\n\n  }\n\n  return sign * parseInt(value, 10);\n}\n\nfunction isInteger(object) {\n  return ('[object Number]' === Object.prototype.toString.call(object)) &&\n         (0 === object % 1 && !common.isNegativeZero(object));\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:int', {\n  kind: 'scalar',\n  resolve: resolveYamlInteger,\n  construct: constructYamlInteger,\n  predicate: isInteger,\n  represent: {\n    binary:      function (object) { return '0b' + object.toString(2); },\n    octal:       function (object) { return '0'  + object.toString(8); },\n    decimal:     function (object) { return        object.toString(10); },\n    hexadecimal: function (object) { return '0x' + object.toString(16).toUpperCase(); }\n  },\n  defaultStyle: 'decimal',\n  styleAliases: {\n    binary:      [ 2,  'bin' ],\n    octal:       [ 8,  'oct' ],\n    decimal:     [ 10, 'dec' ],\n    hexadecimal: [ 16, 'hex' ]\n  }\n});\n","'use strict';\n\nvar esprima;\n\n// Browserified version does not have esprima\n//\n// 1. For node.js just require module as deps\n// 2. For browser try to require mudule via external AMD system.\n//    If not found - try to fallback to window.esprima. If not\n//    found too - then fail to parse.\n//\ntry {\n  esprima = require('esprima');\n} catch (_) {\n  /*global window */\n  if (typeof window !== 'undefined') { esprima = window.esprima; }\n}\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptFunction(data) {\n  if (null === data) {\n    return false;\n  }\n\n  try {\n    var source = '(' + data + ')',\n        ast    = esprima.parse(source, { range: true });\n\n    if ('Program'             !== ast.type         ||\n        1                     !== ast.body.length  ||\n        'ExpressionStatement' !== ast.body[0].type ||\n        'FunctionExpression'  !== ast.body[0].expression.type) {\n      return false;\n    }\n\n    return true;\n  } catch (err) {\n    return false;\n  }\n}\n\nfunction constructJavascriptFunction(data) {\n  /*jslint evil:true*/\n\n  var source = '(' + data + ')',\n      ast    = esprima.parse(source, { range: true }),\n      params = [],\n      body;\n\n  if ('Program'             !== ast.type         ||\n      1                     !== ast.body.length  ||\n      'ExpressionStatement' !== ast.body[0].type ||\n      'FunctionExpression'  !== ast.body[0].expression.type) {\n    throw new Error('Failed to resolve function');\n  }\n\n  ast.body[0].expression.params.forEach(function (param) {\n    params.push(param.name);\n  });\n\n  body = ast.body[0].expression.body.range;\n\n  // Esprima's ranges include the first '{' and the last '}' characters on\n  // function expressions. So cut them out.\n  /*eslint-disable no-new-func*/\n  return new Function(params, source.slice(body[0] + 1, body[1] - 1));\n}\n\nfunction representJavascriptFunction(object /*, style*/) {\n  return object.toString();\n}\n\nfunction isFunction(object) {\n  return '[object Function]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/function', {\n  kind: 'scalar',\n  resolve: resolveJavascriptFunction,\n  construct: constructJavascriptFunction,\n  predicate: isFunction,\n  represent: representJavascriptFunction\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptRegExp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  if (0 === data.length) {\n    return false;\n  }\n\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // if regexp starts with '/' it can have modifiers and must be properly closed\n  // `/foo/gim` - modifiers tail can be maximum 3 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n\n    if (modifiers.length > 3) { return false; }\n    // if expression starts with /, is should be properly terminated\n    if (regexp[regexp.length - modifiers.length - 1] !== '/') { return false; }\n\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  try {\n    return true;\n  } catch (error) {\n    return false;\n  }\n}\n\nfunction constructJavascriptRegExp(data) {\n  var regexp = data,\n      tail   = /\\/([gim]*)$/.exec(data),\n      modifiers = '';\n\n  // `/foo/gim` - tail can be maximum 4 chars\n  if ('/' === regexp[0]) {\n    if (tail) {\n      modifiers = tail[1];\n    }\n    regexp = regexp.slice(1, regexp.length - modifiers.length - 1);\n  }\n\n  return new RegExp(regexp, modifiers);\n}\n\nfunction representJavascriptRegExp(object /*, style*/) {\n  var result = '/' + object.source + '/';\n\n  if (object.global) {\n    result += 'g';\n  }\n\n  if (object.multiline) {\n    result += 'm';\n  }\n\n  if (object.ignoreCase) {\n    result += 'i';\n  }\n\n  return result;\n}\n\nfunction isRegExp(object) {\n  return '[object RegExp]' === Object.prototype.toString.call(object);\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/regexp', {\n  kind: 'scalar',\n  resolve: resolveJavascriptRegExp,\n  construct: constructJavascriptRegExp,\n  predicate: isRegExp,\n  represent: representJavascriptRegExp\n});\n","'use strict';\n\nvar Type = require('../../type');\n\nfunction resolveJavascriptUndefined() {\n  return true;\n}\n\nfunction constructJavascriptUndefined() {\n  /*eslint-disable no-undefined*/\n  return undefined;\n}\n\nfunction representJavascriptUndefined() {\n  return '';\n}\n\nfunction isUndefined(object) {\n  return 'undefined' === typeof object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:js/undefined', {\n  kind: 'scalar',\n  resolve: resolveJavascriptUndefined,\n  construct: constructJavascriptUndefined,\n  predicate: isUndefined,\n  represent: representJavascriptUndefined\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:map', {\n  kind: 'mapping',\n  construct: function (data) { return null !== data ? data : {}; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlMerge(data) {\n  return '<<' === data || null === data;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:merge', {\n  kind: 'scalar',\n  resolve: resolveYamlMerge\n});\n","'use strict';\n\nvar Type = require('../type');\n\nfunction resolveYamlNull(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var max = data.length;\n\n  return (max === 1 && data === '~') ||\n         (max === 4 && (data === 'null' || data === 'Null' || data === 'NULL'));\n}\n\nfunction constructYamlNull() {\n  return null;\n}\n\nfunction isNull(object) {\n  return null === object;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:null', {\n  kind: 'scalar',\n  resolve: resolveYamlNull,\n  construct: constructYamlNull,\n  predicate: isNull,\n  represent: {\n    canonical: function () { return '~';    },\n    lowercase: function () { return 'null'; },\n    uppercase: function () { return 'NULL'; },\n    camelcase: function () { return 'Null'; }\n  },\n  defaultStyle: 'lowercase'\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\nvar _toString       = Object.prototype.toString;\n\nfunction resolveYamlOmap(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var objectKeys = [], index, length, pair, pairKey, pairHasKey,\n      object = data;\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n    pairHasKey = false;\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    for (pairKey in pair) {\n      if (_hasOwnProperty.call(pair, pairKey)) {\n        if (!pairHasKey) {\n          pairHasKey = true;\n        } else {\n          return false;\n        }\n      }\n    }\n\n    if (!pairHasKey) {\n      return false;\n    }\n\n    if (-1 === objectKeys.indexOf(pairKey)) {\n      objectKeys.push(pairKey);\n    } else {\n      return false;\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlOmap(data) {\n  return null !== data ? data : [];\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:omap', {\n  kind: 'sequence',\n  resolve: resolveYamlOmap,\n  construct: constructYamlOmap\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _toString = Object.prototype.toString;\n\nfunction resolveYamlPairs(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    if ('[object Object]' !== _toString.call(pair)) {\n      return false;\n    }\n\n    keys = Object.keys(pair);\n\n    if (1 !== keys.length) {\n      return false;\n    }\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return true;\n}\n\nfunction constructYamlPairs(data) {\n  if (null === data) {\n    return [];\n  }\n\n  var index, length, pair, keys, result,\n      object = data;\n\n  result = new Array(object.length);\n\n  for (index = 0, length = object.length; index < length; index += 1) {\n    pair = object[index];\n\n    keys = Object.keys(pair);\n\n    result[index] = [ keys[0], pair[keys[0]] ];\n  }\n\n  return result;\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:pairs', {\n  kind: 'sequence',\n  resolve: resolveYamlPairs,\n  construct: constructYamlPairs\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:seq', {\n  kind: 'sequence',\n  construct: function (data) { return null !== data ? data : []; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n  if (null === data) {\n    return true;\n  }\n\n  var key, object = data;\n\n  for (key in object) {\n    if (_hasOwnProperty.call(object, key)) {\n      if (null !== object[key]) {\n        return false;\n      }\n    }\n  }\n\n  return true;\n}\n\nfunction constructYamlSet(data) {\n  return null !== data ? data : {};\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:set', {\n  kind: 'mapping',\n  resolve: resolveYamlSet,\n  construct: constructYamlSet\n});\n","'use strict';\n\nvar Type = require('../type');\n\nmodule.exports = new Type('tag:yaml.org,2002:str', {\n  kind: 'scalar',\n  construct: function (data) { return null !== data ? data : ''; }\n});\n","'use strict';\n\nvar Type = require('../type');\n\nvar YAML_TIMESTAMP_REGEXP = new RegExp(\n  '^([0-9][0-9][0-9][0-9])'          + // [1] year\n  '-([0-9][0-9]?)'                   + // [2] month\n  '-([0-9][0-9]?)'                   + // [3] day\n  '(?:(?:[Tt]|[ \\\\t]+)'              + // ...\n  '([0-9][0-9]?)'                    + // [4] hour\n  ':([0-9][0-9])'                    + // [5] minute\n  ':([0-9][0-9])'                    + // [6] second\n  '(?:\\\\.([0-9]*))?'                 + // [7] fraction\n  '(?:[ \\\\t]*(Z|([-+])([0-9][0-9]?)' + // [8] tz [9] tz_sign [10] tz_hour\n  '(?::([0-9][0-9]))?))?)?$');         // [11] tz_minute\n\nfunction resolveYamlTimestamp(data) {\n  if (null === data) {\n    return false;\n  }\n\n  if (YAML_TIMESTAMP_REGEXP.exec(data) === null) {\n    return false;\n  }\n\n  return true;\n}\n\nfunction constructYamlTimestamp(data) {\n  var match, year, month, day, hour, minute, second, fraction = 0,\n      delta = null, tz_hour, tz_minute, date;\n\n  match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n  if (null === match) {\n    throw new Error('Date resolve error');\n  }\n\n  // match: [1] year [2] month [3] day\n\n  year = +(match[1]);\n  month = +(match[2]) - 1; // JS month starts with 0\n  day = +(match[3]);\n\n  if (!match[4]) { // no hour\n    return new Date(Date.UTC(year, month, day));\n  }\n\n  // match: [4] hour [5] minute [6] second [7] fraction\n\n  hour = +(match[4]);\n  minute = +(match[5]);\n  second = +(match[6]);\n\n  if (match[7]) {\n    fraction = match[7].slice(0, 3);\n    while (fraction.length < 3) { // milli-seconds\n      fraction += '0';\n    }\n    fraction = +fraction;\n  }\n\n  // match: [8] tz [9] tz_sign [10] tz_hour [11] tz_minute\n\n  if (match[9]) {\n    tz_hour = +(match[10]);\n    tz_minute = +(match[11] || 0);\n    delta = (tz_hour * 60 + tz_minute) * 60000; // delta in mili-seconds\n    if ('-' === match[9]) {\n      delta = -delta;\n    }\n  }\n\n  date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n  if (delta) {\n    date.setTime(date.getTime() - delta);\n  }\n\n  return date;\n}\n\nfunction representYamlTimestamp(object /*, style*/) {\n  return object.toISOString();\n}\n\nmodule.exports = new Type('tag:yaml.org,2002:timestamp', {\n  kind: 'scalar',\n  resolve: resolveYamlTimestamp,\n  construct: constructYamlTimestamp,\n  instanceOf: Date,\n  represent: representYamlTimestamp\n});\n","/*\n  Copyright (c) jQuery Foundation, Inc. and Contributors, All Rights Reserved.\n\n  Redistribution and use in source and binary forms, with or without\n  modification, are permitted provided that the following conditions are met:\n\n    * Redistributions of source code must retain the above copyright\n      notice, this list of conditions and the following disclaimer.\n    * Redistributions in binary form must reproduce the above copyright\n      notice, this list of conditions and the following disclaimer in the\n      documentation and/or other materials provided with the distribution.\n\n  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n  AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n  ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY\n  DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n  (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND\n  ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF\n  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n(function (root, factory) {\n    'use strict';\n\n    // Universal Module Definition (UMD) to support AMD, CommonJS/Node.js,\n    // Rhino, and plain browser loading.\n\n    /* istanbul ignore next */\n    if (typeof define === 'function' && define.amd) {\n        define(['exports'], factory);\n    } else if (typeof exports !== 'undefined') {\n        factory(exports);\n    } else {\n        factory((root.esprima = {}));\n    }\n}(this, function (exports) {\n    'use strict';\n\n    var Token,\n        TokenName,\n        FnExprTokens,\n        Syntax,\n        PlaceHolders,\n        Messages,\n        Regex,\n        source,\n        strict,\n        index,\n        lineNumber,\n        lineStart,\n        hasLineTerminator,\n        lastIndex,\n        lastLineNumber,\n        lastLineStart,\n        startIndex,\n        startLineNumber,\n        startLineStart,\n        scanning,\n        length,\n        lookahead,\n        state,\n        extra,\n        isBindingElement,\n        isAssignmentTarget,\n        firstCoverInitializedNameError;\n\n    Token = {\n        BooleanLiteral: 1,\n        EOF: 2,\n        Identifier: 3,\n        Keyword: 4,\n        NullLiteral: 5,\n        NumericLiteral: 6,\n        Punctuator: 7,\n        StringLiteral: 8,\n        RegularExpression: 9,\n        Template: 10\n    };\n\n    TokenName = {};\n    TokenName[Token.BooleanLiteral] = 'Boolean';\n    TokenName[Token.EOF] = '<end>';\n    TokenName[Token.Identifier] = 'Identifier';\n    TokenName[Token.Keyword] = 'Keyword';\n    TokenName[Token.NullLiteral] = 'Null';\n    TokenName[Token.NumericLiteral] = 'Numeric';\n    TokenName[Token.Punctuator] = 'Punctuator';\n    TokenName[Token.StringLiteral] = 'String';\n    TokenName[Token.RegularExpression] = 'RegularExpression';\n    TokenName[Token.Template] = 'Template';\n\n    // A function following one of those tokens is an expression.\n    FnExprTokens = ['(', '{', '[', 'in', 'typeof', 'instanceof', 'new',\n                    'return', 'case', 'delete', 'throw', 'void',\n                    // assignment operators\n                    '=', '+=', '-=', '*=', '/=', '%=', '<<=', '>>=', '>>>=',\n                    '&=', '|=', '^=', ',',\n                    // binary/unary operators\n                    '+', '-', '*', '/', '%', '++', '--', '<<', '>>', '>>>', '&',\n                    '|', '^', '!', '~', '&&', '||', '?', ':', '===', '==', '>=',\n                    '<=', '<', '>', '!=', '!=='];\n\n    Syntax = {\n        AssignmentExpression: 'AssignmentExpression',\n        AssignmentPattern: 'AssignmentPattern',\n        ArrayExpression: 'ArrayExpression',\n        ArrayPattern: 'ArrayPattern',\n        ArrowFunctionExpression: 'ArrowFunctionExpression',\n        BlockStatement: 'BlockStatement',\n        BinaryExpression: 'BinaryExpression',\n        BreakStatement: 'BreakStatement',\n        CallExpression: 'CallExpression',\n        CatchClause: 'CatchClause',\n        ClassBody: 'ClassBody',\n        ClassDeclaration: 'ClassDeclaration',\n        ClassExpression: 'ClassExpression',\n        ConditionalExpression: 'ConditionalExpression',\n        ContinueStatement: 'ContinueStatement',\n        DoWhileStatement: 'DoWhileStatement',\n        DebuggerStatement: 'DebuggerStatement',\n        EmptyStatement: 'EmptyStatement',\n        ExportAllDeclaration: 'ExportAllDeclaration',\n        ExportDefaultDeclaration: 'ExportDefaultDeclaration',\n        ExportNamedDeclaration: 'ExportNamedDeclaration',\n        ExportSpecifier: 'ExportSpecifier',\n        ExpressionStatement: 'ExpressionStatement',\n        ForStatement: 'ForStatement',\n        ForOfStatement: 'ForOfStatement',\n        ForInStatement: 'ForInStatement',\n        FunctionDeclaration: 'FunctionDeclaration',\n        FunctionExpression: 'FunctionExpression',\n        Identifier: 'Identifier',\n        IfStatement: 'IfStatement',\n        ImportDeclaration: 'ImportDeclaration',\n        ImportDefaultSpecifier: 'ImportDefaultSpecifier',\n        ImportNamespaceSpecifier: 'ImportNamespaceSpecifier',\n        ImportSpecifier: 'ImportSpecifier',\n        Literal: 'Literal',\n        LabeledStatement: 'LabeledStatement',\n        LogicalExpression: 'LogicalExpression',\n        MemberExpression: 'MemberExpression',\n        MetaProperty: 'MetaProperty',\n        MethodDefinition: 'MethodDefinition',\n        NewExpression: 'NewExpression',\n        ObjectExpression: 'ObjectExpression',\n        ObjectPattern: 'ObjectPattern',\n        Program: 'Program',\n        Property: 'Property',\n        RestElement: 'RestElement',\n        ReturnStatement: 'ReturnStatement',\n        SequenceExpression: 'SequenceExpression',\n        SpreadElement: 'SpreadElement',\n        Super: 'Super',\n        SwitchCase: 'SwitchCase',\n        SwitchStatement: 'SwitchStatement',\n        TaggedTemplateExpression: 'TaggedTemplateExpression',\n        TemplateElement: 'TemplateElement',\n        TemplateLiteral: 'TemplateLiteral',\n        ThisExpression: 'ThisExpression',\n        ThrowStatement: 'ThrowStatement',\n        TryStatement: 'TryStatement',\n        UnaryExpression: 'UnaryExpression',\n        UpdateExpression: 'UpdateExpression',\n        VariableDeclaration: 'VariableDeclaration',\n        VariableDeclarator: 'VariableDeclarator',\n        WhileStatement: 'WhileStatement',\n        WithStatement: 'WithStatement',\n        YieldExpression: 'YieldExpression'\n    };\n\n    PlaceHolders = {\n        ArrowParameterPlaceHolder: 'ArrowParameterPlaceHolder'\n    };\n\n    // Error messages should be identical to V8.\n    Messages = {\n        UnexpectedToken: 'Unexpected token %0',\n        UnexpectedNumber: 'Unexpected number',\n        UnexpectedString: 'Unexpected string',\n        UnexpectedIdentifier: 'Unexpected identifier',\n        UnexpectedReserved: 'Unexpected reserved word',\n        UnexpectedTemplate: 'Unexpected quasi %0',\n        UnexpectedEOS: 'Unexpected end of input',\n        NewlineAfterThrow: 'Illegal newline after throw',\n        InvalidRegExp: 'Invalid regular expression',\n        UnterminatedRegExp: 'Invalid regular expression: missing /',\n        InvalidLHSInAssignment: 'Invalid left-hand side in assignment',\n        InvalidLHSInForIn: 'Invalid left-hand side in for-in',\n        InvalidLHSInForLoop: 'Invalid left-hand side in for-loop',\n        MultipleDefaultsInSwitch: 'More than one default clause in switch statement',\n        NoCatchOrFinally: 'Missing catch or finally after try',\n        UnknownLabel: 'Undefined label \\'%0\\'',\n        Redeclaration: '%0 \\'%1\\' has already been declared',\n        IllegalContinue: 'Illegal continue statement',\n        IllegalBreak: 'Illegal break statement',\n        IllegalReturn: 'Illegal return statement',\n        StrictModeWith: 'Strict mode code may not include a with statement',\n        StrictCatchVariable: 'Catch variable may not be eval or arguments in strict mode',\n        StrictVarName: 'Variable name may not be eval or arguments in strict mode',\n        StrictParamName: 'Parameter name eval or arguments is not allowed in strict mode',\n        StrictParamDupe: 'Strict mode function may not have duplicate parameter names',\n        StrictFunctionName: 'Function name may not be eval or arguments in strict mode',\n        StrictOctalLiteral: 'Octal literals are not allowed in strict mode.',\n        StrictDelete: 'Delete of an unqualified identifier in strict mode.',\n        StrictLHSAssignment: 'Assignment to eval or arguments is not allowed in strict mode',\n        StrictLHSPostfix: 'Postfix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictLHSPrefix: 'Prefix increment/decrement may not have eval or arguments operand in strict mode',\n        StrictReservedWord: 'Use of future reserved word in strict mode',\n        TemplateOctalLiteral: 'Octal literals are not allowed in template strings.',\n        ParameterAfterRestParameter: 'Rest parameter must be last formal parameter',\n        DefaultRestParameter: 'Unexpected token =',\n        ObjectPatternAsRestParameter: 'Unexpected token {',\n        DuplicateProtoProperty: 'Duplicate __proto__ fields are not allowed in object literals',\n        ConstructorSpecialMethod: 'Class constructor may not be an accessor',\n        DuplicateConstructor: 'A class may only have one constructor',\n        StaticPrototype: 'Classes may not have static property named prototype',\n        MissingFromClause: 'Unexpected token',\n        NoAsAfterImportNamespace: 'Unexpected token',\n        InvalidModuleSpecifier: 'Unexpected token',\n        IllegalImportDeclaration: 'Unexpected token',\n        IllegalExportDeclaration: 'Unexpected token',\n        DuplicateBinding: 'Duplicate binding %0'\n    };\n\n    // See also tools/generate-unicode-regex.js.\n    Regex = {\n        // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierStart:\n        NonAsciiIdentifierStart: /[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0370-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u07F4\\u07F5\\u07FA\\u0800-\\u0815\\u081A\\u0824\\u0828\\u0840-\\u0858\\u08A0-\\u08B2\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0971-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58\\u0C59\\u0C60\\u0C61\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D60\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E46\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17D7\\u17DC\\u1820-\\u1877\\u1880-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19C1-\\u19C7\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1AA7\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C7D\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u1D00-\\u1DBF\\u1E00-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u2071\\u207F\\u2090-\\u209C\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2118-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CEE\\u2CF2\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u3005-\\u3007\\u3021-\\u3029\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u309B-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA61F\\uA62A\\uA62B\\uA640-\\uA66E\\uA67F-\\uA69D\\uA6A0-\\uA6EF\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9CF\\uA9E0-\\uA9E4\\uA9E6-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEA\\uAAF2-\\uAAF4\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF21-\\uFF3A\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]|\\uD800[\\uDC00-\\uDC0B\\uDC0D-\\uDC26\\uDC28-\\uDC3A\\uDC3C\\uDC3D\\uDC3F-\\uDC4D\\uDC50-\\uDC5D\\uDC80-\\uDCFA\\uDD40-\\uDD74\\uDE80-\\uDE9C\\uDEA0-\\uDED0\\uDF00-\\uDF1F\\uDF30-\\uDF4A\\uDF50-\\uDF75\\uDF80-\\uDF9D\\uDFA0-\\uDFC3\\uDFC8-\\uDFCF\\uDFD1-\\uDFD5]|\\uD801[\\uDC00-\\uDC9D\\uDD00-\\uDD27\\uDD30-\\uDD63\\uDE00-\\uDF36\\uDF40-\\uDF55\\uDF60-\\uDF67]|\\uD802[\\uDC00-\\uDC05\\uDC08\\uDC0A-\\uDC35\\uDC37\\uDC38\\uDC3C\\uDC3F-\\uDC55\\uDC60-\\uDC76\\uDC80-\\uDC9E\\uDD00-\\uDD15\\uDD20-\\uDD39\\uDD80-\\uDDB7\\uDDBE\\uDDBF\\uDE00\\uDE10-\\uDE13\\uDE15-\\uDE17\\uDE19-\\uDE33\\uDE60-\\uDE7C\\uDE80-\\uDE9C\\uDEC0-\\uDEC7\\uDEC9-\\uDEE4\\uDF00-\\uDF35\\uDF40-\\uDF55\\uDF60-\\uDF72\\uDF80-\\uDF91]|\\uD803[\\uDC00-\\uDC48]|\\uD804[\\uDC03-\\uDC37\\uDC83-\\uDCAF\\uDCD0-\\uDCE8\\uDD03-\\uDD26\\uDD50-\\uDD72\\uDD76\\uDD83-\\uDDB2\\uDDC1-\\uDDC4\\uDDDA\\uDE00-\\uDE11\\uDE13-\\uDE2B\\uDEB0-\\uDEDE\\uDF05-\\uDF0C\\uDF0F\\uDF10\\uDF13-\\uDF28\\uDF2A-\\uDF30\\uDF32\\uDF33\\uDF35-\\uDF39\\uDF3D\\uDF5D-\\uDF61]|\\uD805[\\uDC80-\\uDCAF\\uDCC4\\uDCC5\\uDCC7\\uDD80-\\uDDAE\\uDE00-\\uDE2F\\uDE44\\uDE80-\\uDEAA]|\\uD806[\\uDCA0-\\uDCDF\\uDCFF\\uDEC0-\\uDEF8]|\\uD808[\\uDC00-\\uDF98]|\\uD809[\\uDC00-\\uDC6E]|[\\uD80C\\uD840-\\uD868\\uD86A-\\uD86C][\\uDC00-\\uDFFF]|\\uD80D[\\uDC00-\\uDC2E]|\\uD81A[\\uDC00-\\uDE38\\uDE40-\\uDE5E\\uDED0-\\uDEED\\uDF00-\\uDF2F\\uDF40-\\uDF43\\uDF63-\\uDF77\\uDF7D-\\uDF8F]|\\uD81B[\\uDF00-\\uDF44\\uDF50\\uDF93-\\uDF9F]|\\uD82C[\\uDC00\\uDC01]|\\uD82F[\\uDC00-\\uDC6A\\uDC70-\\uDC7C\\uDC80-\\uDC88\\uDC90-\\uDC99]|\\uD835[\\uDC00-\\uDC54\\uDC56-\\uDC9C\\uDC9E\\uDC9F\\uDCA2\\uDCA5\\uDCA6\\uDCA9-\\uDCAC\\uDCAE-\\uDCB9\\uDCBB\\uDCBD-\\uDCC3\\uDCC5-\\uDD05\\uDD07-\\uDD0A\\uDD0D-\\uDD14\\uDD16-\\uDD1C\\uDD1E-\\uDD39\\uDD3B-\\uDD3E\\uDD40-\\uDD44\\uDD46\\uDD4A-\\uDD50\\uDD52-\\uDEA5\\uDEA8-\\uDEC0\\uDEC2-\\uDEDA\\uDEDC-\\uDEFA\\uDEFC-\\uDF14\\uDF16-\\uDF34\\uDF36-\\uDF4E\\uDF50-\\uDF6E\\uDF70-\\uDF88\\uDF8A-\\uDFA8\\uDFAA-\\uDFC2\\uDFC4-\\uDFCB]|\\uD83A[\\uDC00-\\uDCC4]|\\uD83B[\\uDE00-\\uDE03\\uDE05-\\uDE1F\\uDE21\\uDE22\\uDE24\\uDE27\\uDE29-\\uDE32\\uDE34-\\uDE37\\uDE39\\uDE3B\\uDE42\\uDE47\\uDE49\\uDE4B\\uDE4D-\\uDE4F\\uDE51\\uDE52\\uDE54\\uDE57\\uDE59\\uDE5B\\uDE5D\\uDE5F\\uDE61\\uDE62\\uDE64\\uDE67-\\uDE6A\\uDE6C-\\uDE72\\uDE74-\\uDE77\\uDE79-\\uDE7C\\uDE7E\\uDE80-\\uDE89\\uDE8B-\\uDE9B\\uDEA1-\\uDEA3\\uDEA5-\\uDEA9\\uDEAB-\\uDEBB]|\\uD869[\\uDC00-\\uDED6\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF34\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D]|\\uD87E[\\uDC00-\\uDE1D]/,\n\n        // ECMAScript 6/Unicode v7.0.0 NonAsciiIdentifierPart:\n        NonAsciiIdentifierPart: /[\\xAA\\xB5\\xB7\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0300-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u0483-\\u0487\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u0591-\\u05BD\\u05BF\\u05C1\\u05C2\\u05C4\\u05C5\\u05C7\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0610-\\u061A\\u0620-\\u0669\\u066E-\\u06D3\\u06D5-\\u06DC\\u06DF-\\u06E8\\u06EA-\\u06FC\\u06FF\\u0710-\\u074A\\u074D-\\u07B1\\u07C0-\\u07F5\\u07FA\\u0800-\\u082D\\u0840-\\u085B\\u08A0-\\u08B2\\u08E4-\\u0963\\u0966-\\u096F\\u0971-\\u0983\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BC-\\u09C4\\u09C7\\u09C8\\u09CB-\\u09CE\\u09D7\\u09DC\\u09DD\\u09DF-\\u09E3\\u09E6-\\u09F1\\u0A01-\\u0A03\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A3C\\u0A3E-\\u0A42\\u0A47\\u0A48\\u0A4B-\\u0A4D\\u0A51\\u0A59-\\u0A5C\\u0A5E\\u0A66-\\u0A75\\u0A81-\\u0A83\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABC-\\u0AC5\\u0AC7-\\u0AC9\\u0ACB-\\u0ACD\\u0AD0\\u0AE0-\\u0AE3\\u0AE6-\\u0AEF\\u0B01-\\u0B03\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3C-\\u0B44\\u0B47\\u0B48\\u0B4B-\\u0B4D\\u0B56\\u0B57\\u0B5C\\u0B5D\\u0B5F-\\u0B63\\u0B66-\\u0B6F\\u0B71\\u0B82\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BBE-\\u0BC2\\u0BC6-\\u0BC8\\u0BCA-\\u0BCD\\u0BD0\\u0BD7\\u0BE6-\\u0BEF\\u0C00-\\u0C03\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D-\\u0C44\\u0C46-\\u0C48\\u0C4A-\\u0C4D\\u0C55\\u0C56\\u0C58\\u0C59\\u0C60-\\u0C63\\u0C66-\\u0C6F\\u0C81-\\u0C83\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBC-\\u0CC4\\u0CC6-\\u0CC8\\u0CCA-\\u0CCD\\u0CD5\\u0CD6\\u0CDE\\u0CE0-\\u0CE3\\u0CE6-\\u0CEF\\u0CF1\\u0CF2\\u0D01-\\u0D03\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D-\\u0D44\\u0D46-\\u0D48\\u0D4A-\\u0D4E\\u0D57\\u0D60-\\u0D63\\u0D66-\\u0D6F\\u0D7A-\\u0D7F\\u0D82\\u0D83\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0DCA\\u0DCF-\\u0DD4\\u0DD6\\u0DD8-\\u0DDF\\u0DE6-\\u0DEF\\u0DF2\\u0DF3\\u0E01-\\u0E3A\\u0E40-\\u0E4E\\u0E50-\\u0E59\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB9\\u0EBB-\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EC8-\\u0ECD\\u0ED0-\\u0ED9\\u0EDC-\\u0EDF\\u0F00\\u0F18\\u0F19\\u0F20-\\u0F29\\u0F35\\u0F37\\u0F39\\u0F3E-\\u0F47\\u0F49-\\u0F6C\\u0F71-\\u0F84\\u0F86-\\u0F97\\u0F99-\\u0FBC\\u0FC6\\u1000-\\u1049\\u1050-\\u109D\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u135D-\\u135F\\u1369-\\u1371\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1714\\u1720-\\u1734\\u1740-\\u1753\\u1760-\\u176C\\u176E-\\u1770\\u1772\\u1773\\u1780-\\u17D3\\u17D7\\u17DC\\u17DD\\u17E0-\\u17E9\\u180B-\\u180D\\u1810-\\u1819\\u1820-\\u1877\\u1880-\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1920-\\u192B\\u1930-\\u193B\\u1946-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u19D0-\\u19DA\\u1A00-\\u1A1B\\u1A20-\\u1A5E\\u1A60-\\u1A7C\\u1A7F-\\u1A89\\u1A90-\\u1A99\\u1AA7\\u1AB0-\\u1ABD\\u1B00-\\u1B4B\\u1B50-\\u1B59\\u1B6B-\\u1B73\\u1B80-\\u1BF3\\u1C00-\\u1C37\\u1C40-\\u1C49\\u1C4D-\\u1C7D\\u1CD0-\\u1CD2\\u1CD4-\\u1CF6\\u1CF8\\u1CF9\\u1D00-\\u1DF5\\u1DFC-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u200C\\u200D\\u203F\\u2040\\u2054\\u2071\\u207F\\u2090-\\u209C\\u20D0-\\u20DC\\u20E1\\u20E5-\\u20F0\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2118-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D7F-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2DE0-\\u2DFF\\u3005-\\u3007\\u3021-\\u302F\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u3099-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA62B\\uA640-\\uA66F\\uA674-\\uA67D\\uA67F-\\uA69D\\uA69F-\\uA6F1\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA827\\uA840-\\uA873\\uA880-\\uA8C4\\uA8D0-\\uA8D9\\uA8E0-\\uA8F7\\uA8FB\\uA900-\\uA92D\\uA930-\\uA953\\uA960-\\uA97C\\uA980-\\uA9C0\\uA9CF-\\uA9D9\\uA9E0-\\uA9FE\\uAA00-\\uAA36\\uAA40-\\uAA4D\\uAA50-\\uAA59\\uAA60-\\uAA76\\uAA7A-\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEF\\uAAF2-\\uAAF6\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABEA\\uABEC\\uABED\\uABF0-\\uABF9\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE00-\\uFE0F\\uFE20-\\uFE2D\\uFE33\\uFE34\\uFE4D-\\uFE4F\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF10-\\uFF19\\uFF21-\\uFF3A\\uFF3F\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]|\\uD800[\\uDC00-\\uDC0B\\uDC0D-\\uDC26\\uDC28-\\uDC3A\\uDC3C\\uDC3D\\uDC3F-\\uDC4D\\uDC50-\\uDC5D\\uDC80-\\uDCFA\\uDD40-\\uDD74\\uDDFD\\uDE80-\\uDE9C\\uDEA0-\\uDED0\\uDEE0\\uDF00-\\uDF1F\\uDF30-\\uDF4A\\uDF50-\\uDF7A\\uDF80-\\uDF9D\\uDFA0-\\uDFC3\\uDFC8-\\uDFCF\\uDFD1-\\uDFD5]|\\uD801[\\uDC00-\\uDC9D\\uDCA0-\\uDCA9\\uDD00-\\uDD27\\uDD30-\\uDD63\\uDE00-\\uDF36\\uDF40-\\uDF55\\uDF60-\\uDF67]|\\uD802[\\uDC00-\\uDC05\\uDC08\\uDC0A-\\uDC35\\uDC37\\uDC38\\uDC3C\\uDC3F-\\uDC55\\uDC60-\\uDC76\\uDC80-\\uDC9E\\uDD00-\\uDD15\\uDD20-\\uDD39\\uDD80-\\uDDB7\\uDDBE\\uDDBF\\uDE00-\\uDE03\\uDE05\\uDE06\\uDE0C-\\uDE13\\uDE15-\\uDE17\\uDE19-\\uDE33\\uDE38-\\uDE3A\\uDE3F\\uDE60-\\uDE7C\\uDE80-\\uDE9C\\uDEC0-\\uDEC7\\uDEC9-\\uDEE6\\uDF00-\\uDF35\\uDF40-\\uDF55\\uDF60-\\uDF72\\uDF80-\\uDF91]|\\uD803[\\uDC00-\\uDC48]|\\uD804[\\uDC00-\\uDC46\\uDC66-\\uDC6F\\uDC7F-\\uDCBA\\uDCD0-\\uDCE8\\uDCF0-\\uDCF9\\uDD00-\\uDD34\\uDD36-\\uDD3F\\uDD50-\\uDD73\\uDD76\\uDD80-\\uDDC4\\uDDD0-\\uDDDA\\uDE00-\\uDE11\\uDE13-\\uDE37\\uDEB0-\\uDEEA\\uDEF0-\\uDEF9\\uDF01-\\uDF03\\uDF05-\\uDF0C\\uDF0F\\uDF10\\uDF13-\\uDF28\\uDF2A-\\uDF30\\uDF32\\uDF33\\uDF35-\\uDF39\\uDF3C-\\uDF44\\uDF47\\uDF48\\uDF4B-\\uDF4D\\uDF57\\uDF5D-\\uDF63\\uDF66-\\uDF6C\\uDF70-\\uDF74]|\\uD805[\\uDC80-\\uDCC5\\uDCC7\\uDCD0-\\uDCD9\\uDD80-\\uDDB5\\uDDB8-\\uDDC0\\uDE00-\\uDE40\\uDE44\\uDE50-\\uDE59\\uDE80-\\uDEB7\\uDEC0-\\uDEC9]|\\uD806[\\uDCA0-\\uDCE9\\uDCFF\\uDEC0-\\uDEF8]|\\uD808[\\uDC00-\\uDF98]|\\uD809[\\uDC00-\\uDC6E]|[\\uD80C\\uD840-\\uD868\\uD86A-\\uD86C][\\uDC00-\\uDFFF]|\\uD80D[\\uDC00-\\uDC2E]|\\uD81A[\\uDC00-\\uDE38\\uDE40-\\uDE5E\\uDE60-\\uDE69\\uDED0-\\uDEED\\uDEF0-\\uDEF4\\uDF00-\\uDF36\\uDF40-\\uDF43\\uDF50-\\uDF59\\uDF63-\\uDF77\\uDF7D-\\uDF8F]|\\uD81B[\\uDF00-\\uDF44\\uDF50-\\uDF7E\\uDF8F-\\uDF9F]|\\uD82C[\\uDC00\\uDC01]|\\uD82F[\\uDC00-\\uDC6A\\uDC70-\\uDC7C\\uDC80-\\uDC88\\uDC90-\\uDC99\\uDC9D\\uDC9E]|\\uD834[\\uDD65-\\uDD69\\uDD6D-\\uDD72\\uDD7B-\\uDD82\\uDD85-\\uDD8B\\uDDAA-\\uDDAD\\uDE42-\\uDE44]|\\uD835[\\uDC00-\\uDC54\\uDC56-\\uDC9C\\uDC9E\\uDC9F\\uDCA2\\uDCA5\\uDCA6\\uDCA9-\\uDCAC\\uDCAE-\\uDCB9\\uDCBB\\uDCBD-\\uDCC3\\uDCC5-\\uDD05\\uDD07-\\uDD0A\\uDD0D-\\uDD14\\uDD16-\\uDD1C\\uDD1E-\\uDD39\\uDD3B-\\uDD3E\\uDD40-\\uDD44\\uDD46\\uDD4A-\\uDD50\\uDD52-\\uDEA5\\uDEA8-\\uDEC0\\uDEC2-\\uDEDA\\uDEDC-\\uDEFA\\uDEFC-\\uDF14\\uDF16-\\uDF34\\uDF36-\\uDF4E\\uDF50-\\uDF6E\\uDF70-\\uDF88\\uDF8A-\\uDFA8\\uDFAA-\\uDFC2\\uDFC4-\\uDFCB\\uDFCE-\\uDFFF]|\\uD83A[\\uDC00-\\uDCC4\\uDCD0-\\uDCD6]|\\uD83B[\\uDE00-\\uDE03\\uDE05-\\uDE1F\\uDE21\\uDE22\\uDE24\\uDE27\\uDE29-\\uDE32\\uDE34-\\uDE37\\uDE39\\uDE3B\\uDE42\\uDE47\\uDE49\\uDE4B\\uDE4D-\\uDE4F\\uDE51\\uDE52\\uDE54\\uDE57\\uDE59\\uDE5B\\uDE5D\\uDE5F\\uDE61\\uDE62\\uDE64\\uDE67-\\uDE6A\\uDE6C-\\uDE72\\uDE74-\\uDE77\\uDE79-\\uDE7C\\uDE7E\\uDE80-\\uDE89\\uDE8B-\\uDE9B\\uDEA1-\\uDEA3\\uDEA5-\\uDEA9\\uDEAB-\\uDEBB]|\\uD869[\\uDC00-\\uDED6\\uDF00-\\uDFFF]|\\uD86D[\\uDC00-\\uDF34\\uDF40-\\uDFFF]|\\uD86E[\\uDC00-\\uDC1D]|\\uD87E[\\uDC00-\\uDE1D]|\\uDB40[\\uDD00-\\uDDEF]/\n    };\n\n    // Ensure the condition is true, otherwise throw an error.\n    // This is only to have a better contract semantic, i.e. another safety net\n    // to catch a logic error. The condition shall be fulfilled in normal case.\n    // Do NOT use this to enforce a certain condition on any user input.\n\n    function assert(condition, message) {\n        /* istanbul ignore if */\n        if (!condition) {\n            throw new Error('ASSERT: ' + message);\n        }\n    }\n\n    function isDecimalDigit(ch) {\n        return (ch >= 0x30 && ch <= 0x39);   // 0..9\n    }\n\n    function isHexDigit(ch) {\n        return '0123456789abcdefABCDEF'.indexOf(ch) >= 0;\n    }\n\n    function isOctalDigit(ch) {\n        return '01234567'.indexOf(ch) >= 0;\n    }\n\n    function octalToDecimal(ch) {\n        // \\0 is not octal escape sequence\n        var octal = (ch !== '0'), code = '01234567'.indexOf(ch);\n\n        if (index < length && isOctalDigit(source[index])) {\n            octal = true;\n            code = code * 8 + '01234567'.indexOf(source[index++]);\n\n            // 3 digits are only allowed when string starts\n            // with 0, 1, 2, 3\n            if ('0123'.indexOf(ch) >= 0 &&\n                    index < length &&\n                    isOctalDigit(source[index])) {\n                code = code * 8 + '01234567'.indexOf(source[index++]);\n            }\n        }\n\n        return {\n            code: code,\n            octal: octal\n        };\n    }\n\n    // ECMA-262 11.2 White Space\n\n    function isWhiteSpace(ch) {\n        return (ch === 0x20) || (ch === 0x09) || (ch === 0x0B) || (ch === 0x0C) || (ch === 0xA0) ||\n            (ch >= 0x1680 && [0x1680, 0x180E, 0x2000, 0x2001, 0x2002, 0x2003, 0x2004, 0x2005, 0x2006, 0x2007, 0x2008, 0x2009, 0x200A, 0x202F, 0x205F, 0x3000, 0xFEFF].indexOf(ch) >= 0);\n    }\n\n    // ECMA-262 11.3 Line Terminators\n\n    function isLineTerminator(ch) {\n        return (ch === 0x0A) || (ch === 0x0D) || (ch === 0x2028) || (ch === 0x2029);\n    }\n\n    // ECMA-262 11.6 Identifier Names and Identifiers\n\n    function fromCodePoint(cp) {\n        return (cp < 0x10000) ? String.fromCharCode(cp) :\n            String.fromCharCode(0xD800 + ((cp - 0x10000) >> 10)) +\n            String.fromCharCode(0xDC00 + ((cp - 0x10000) & 1023));\n    }\n\n    function isIdentifierStart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierStart.test(fromCodePoint(ch)));\n    }\n\n    function isIdentifierPart(ch) {\n        return (ch === 0x24) || (ch === 0x5F) ||  // $ (dollar) and _ (underscore)\n            (ch >= 0x41 && ch <= 0x5A) ||         // A..Z\n            (ch >= 0x61 && ch <= 0x7A) ||         // a..z\n            (ch >= 0x30 && ch <= 0x39) ||         // 0..9\n            (ch === 0x5C) ||                      // \\ (backslash)\n            ((ch >= 0x80) && Regex.NonAsciiIdentifierPart.test(fromCodePoint(ch)));\n    }\n\n    // ECMA-262 11.6.2.2 Future Reserved Words\n\n    function isFutureReservedWord(id) {\n        switch (id) {\n        case 'enum':\n        case 'export':\n        case 'import':\n        case 'super':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    function isStrictModeReservedWord(id) {\n        switch (id) {\n        case 'implements':\n        case 'interface':\n        case 'package':\n        case 'private':\n        case 'protected':\n        case 'public':\n        case 'static':\n        case 'yield':\n        case 'let':\n            return true;\n        default:\n            return false;\n        }\n    }\n\n    function isRestrictedWord(id) {\n        return id === 'eval' || id === 'arguments';\n    }\n\n    // ECMA-262 11.6.2.1 Keywords\n\n    function isKeyword(id) {\n        switch (id.length) {\n        case 2:\n            return (id === 'if') || (id === 'in') || (id === 'do');\n        case 3:\n            return (id === 'var') || (id === 'for') || (id === 'new') ||\n                (id === 'try') || (id === 'let');\n        case 4:\n            return (id === 'this') || (id === 'else') || (id === 'case') ||\n                (id === 'void') || (id === 'with') || (id === 'enum');\n        case 5:\n            return (id === 'while') || (id === 'break') || (id === 'catch') ||\n                (id === 'throw') || (id === 'const') || (id === 'yield') ||\n                (id === 'class') || (id === 'super');\n        case 6:\n            return (id === 'return') || (id === 'typeof') || (id === 'delete') ||\n                (id === 'switch') || (id === 'export') || (id === 'import');\n        case 7:\n            return (id === 'default') || (id === 'finally') || (id === 'extends');\n        case 8:\n            return (id === 'function') || (id === 'continue') || (id === 'debugger');\n        case 10:\n            return (id === 'instanceof');\n        default:\n            return false;\n        }\n    }\n\n    // ECMA-262 11.4 Comments\n\n    function addComment(type, value, start, end, loc) {\n        var comment;\n\n        assert(typeof start === 'number', 'Comment must have valid position');\n\n        state.lastCommentStart = start;\n\n        comment = {\n            type: type,\n            value: value\n        };\n        if (extra.range) {\n            comment.range = [start, end];\n        }\n        if (extra.loc) {\n            comment.loc = loc;\n        }\n        extra.comments.push(comment);\n        if (extra.attachComment) {\n            extra.leadingComments.push(comment);\n            extra.trailingComments.push(comment);\n        }\n        if (extra.tokenize) {\n            comment.type = comment.type + 'Comment';\n            if (extra.delegate) {\n                comment = extra.delegate(comment);\n            }\n            extra.tokens.push(comment);\n        }\n    }\n\n    function skipSingleLineComment(offset) {\n        var start, loc, ch, comment;\n\n        start = index - offset;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart - offset\n            }\n        };\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            ++index;\n            if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                if (extra.comments) {\n                    comment = source.slice(start + offset, index - 1);\n                    loc.end = {\n                        line: lineNumber,\n                        column: index - lineStart - 1\n                    };\n                    addComment('Line', comment, start, index - 1, loc);\n                }\n                if (ch === 13 && source.charCodeAt(index) === 10) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                return;\n            }\n        }\n\n        if (extra.comments) {\n            comment = source.slice(start + offset, index);\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            addComment('Line', comment, start, index, loc);\n        }\n    }\n\n    function skipMultiLineComment() {\n        var start, loc, ch, comment;\n\n        if (extra.comments) {\n            start = index - 2;\n            loc = {\n                start: {\n                    line: lineNumber,\n                    column: index - lineStart - 2\n                }\n            };\n        }\n\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (isLineTerminator(ch)) {\n                if (ch === 0x0D && source.charCodeAt(index + 1) === 0x0A) {\n                    ++index;\n                }\n                hasLineTerminator = true;\n                ++lineNumber;\n                ++index;\n                lineStart = index;\n            } else if (ch === 0x2A) {\n                // Block comment ends with '*/'.\n                if (source.charCodeAt(index + 1) === 0x2F) {\n                    ++index;\n                    ++index;\n                    if (extra.comments) {\n                        comment = source.slice(start + 2, index - 2);\n                        loc.end = {\n                            line: lineNumber,\n                            column: index - lineStart\n                        };\n                        addComment('Block', comment, start, index, loc);\n                    }\n                    return;\n                }\n                ++index;\n            } else {\n                ++index;\n            }\n        }\n\n        // Ran off the end of the file - the whole thing is a comment\n        if (extra.comments) {\n            loc.end = {\n                line: lineNumber,\n                column: index - lineStart\n            };\n            comment = source.slice(start + 2, index);\n            addComment('Block', comment, start, index, loc);\n        }\n        tolerateUnexpectedToken();\n    }\n\n    function skipComment() {\n        var ch, start;\n        hasLineTerminator = false;\n\n        start = (index === 0);\n        while (index < length) {\n            ch = source.charCodeAt(index);\n\n            if (isWhiteSpace(ch)) {\n                ++index;\n            } else if (isLineTerminator(ch)) {\n                hasLineTerminator = true;\n                ++index;\n                if (ch === 0x0D && source.charCodeAt(index) === 0x0A) {\n                    ++index;\n                }\n                ++lineNumber;\n                lineStart = index;\n                start = true;\n            } else if (ch === 0x2F) { // U+002F is '/'\n                ch = source.charCodeAt(index + 1);\n                if (ch === 0x2F) {\n                    ++index;\n                    ++index;\n                    skipSingleLineComment(2);\n                    start = true;\n                } else if (ch === 0x2A) {  // U+002A is '*'\n                    ++index;\n                    ++index;\n                    skipMultiLineComment();\n                } else {\n                    break;\n                }\n            } else if (start && ch === 0x2D) { // U+002D is '-'\n                // U+003E is '>'\n                if ((source.charCodeAt(index + 1) === 0x2D) && (source.charCodeAt(index + 2) === 0x3E)) {\n                    // '-->' is a single-line comment\n                    index += 3;\n                    skipSingleLineComment(3);\n                } else {\n                    break;\n                }\n            } else if (ch === 0x3C) { // U+003C is '<'\n                if (source.slice(index + 1, index + 4) === '!--') {\n                    ++index; // `<`\n                    ++index; // `!`\n                    ++index; // `-`\n                    ++index; // `-`\n                    skipSingleLineComment(4);\n                } else {\n                    break;\n                }\n            } else {\n                break;\n            }\n        }\n    }\n\n    function scanHexEscape(prefix) {\n        var i, len, ch, code = 0;\n\n        len = (prefix === 'u') ? 4 : 2;\n        for (i = 0; i < len; ++i) {\n            if (index < length && isHexDigit(source[index])) {\n                ch = source[index++];\n                code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n            } else {\n                return '';\n            }\n        }\n        return String.fromCharCode(code);\n    }\n\n    function scanUnicodeCodePointEscape() {\n        var ch, code;\n\n        ch = source[index];\n        code = 0;\n\n        // At least, one hex digit is required.\n        if (ch === '}') {\n            throwUnexpectedToken();\n        }\n\n        while (index < length) {\n            ch = source[index++];\n            if (!isHexDigit(ch)) {\n                break;\n            }\n            code = code * 16 + '0123456789abcdef'.indexOf(ch.toLowerCase());\n        }\n\n        if (code > 0x10FFFF || ch !== '}') {\n            throwUnexpectedToken();\n        }\n\n        return fromCodePoint(code);\n    }\n\n    function codePointAt(i) {\n        var cp, first, second;\n\n        cp = source.charCodeAt(i);\n        if (cp >= 0xD800 && cp <= 0xDBFF) {\n            second = source.charCodeAt(i + 1);\n            if (second >= 0xDC00 && second <= 0xDFFF) {\n                first = cp;\n                cp = (first - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n            }\n        }\n\n        return cp;\n    }\n\n    function getComplexIdentifier() {\n        var cp, ch, id;\n\n        cp = codePointAt(index);\n        id = fromCodePoint(cp);\n        index += id.length;\n\n        // '\\u' (U+005C, U+0075) denotes an escaped character.\n        if (cp === 0x5C) {\n            if (source.charCodeAt(index) !== 0x75) {\n                throwUnexpectedToken();\n            }\n            ++index;\n            if (source[index] === '{') {\n                ++index;\n                ch = scanUnicodeCodePointEscape();\n            } else {\n                ch = scanHexEscape('u');\n                cp = ch.charCodeAt(0);\n                if (!ch || ch === '\\\\' || !isIdentifierStart(cp)) {\n                    throwUnexpectedToken();\n                }\n            }\n            id = ch;\n        }\n\n        while (index < length) {\n            cp = codePointAt(index);\n            if (!isIdentifierPart(cp)) {\n                break;\n            }\n            ch = fromCodePoint(cp);\n            id += ch;\n            index += ch.length;\n\n            // '\\u' (U+005C, U+0075) denotes an escaped character.\n            if (cp === 0x5C) {\n                id = id.substr(0, id.length - 1);\n                if (source.charCodeAt(index) !== 0x75) {\n                    throwUnexpectedToken();\n                }\n                ++index;\n                if (source[index] === '{') {\n                    ++index;\n                    ch = scanUnicodeCodePointEscape();\n                } else {\n                    ch = scanHexEscape('u');\n                    cp = ch.charCodeAt(0);\n                    if (!ch || ch === '\\\\' || !isIdentifierPart(cp)) {\n                        throwUnexpectedToken();\n                    }\n                }\n                id += ch;\n            }\n        }\n\n        return id;\n    }\n\n    function getIdentifier() {\n        var start, ch;\n\n        start = index++;\n        while (index < length) {\n            ch = source.charCodeAt(index);\n            if (ch === 0x5C) {\n                // Blackslash (U+005C) marks Unicode escape sequence.\n                index = start;\n                return getComplexIdentifier();\n            } else if (ch >= 0xD800 && ch < 0xDFFF) {\n                // Need to handle surrogate pairs.\n                index = start;\n                return getComplexIdentifier();\n            }\n            if (isIdentifierPart(ch)) {\n                ++index;\n            } else {\n                break;\n            }\n        }\n\n        return source.slice(start, index);\n    }\n\n    function scanIdentifier() {\n        var start, id, type;\n\n        start = index;\n\n        // Backslash (U+005C) starts an escaped character.\n        id = (source.charCodeAt(index) === 0x5C) ? getComplexIdentifier() : getIdentifier();\n\n        // There is no keyword or literal with only one character.\n        // Thus, it must be an identifier.\n        if (id.length === 1) {\n            type = Token.Identifier;\n        } else if (isKeyword(id)) {\n            type = Token.Keyword;\n        } else if (id === 'null') {\n            type = Token.NullLiteral;\n        } else if (id === 'true' || id === 'false') {\n            type = Token.BooleanLiteral;\n        } else {\n            type = Token.Identifier;\n        }\n\n        return {\n            type: type,\n            value: id,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n\n    // ECMA-262 11.7 Punctuators\n\n    function scanPunctuator() {\n        var token, str;\n\n        token = {\n            type: Token.Punctuator,\n            value: '',\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: index,\n            end: index\n        };\n\n        // Check for most common single-character punctuators.\n        str = source[index];\n        switch (str) {\n\n        case '(':\n            if (extra.tokenize) {\n                extra.openParenToken = extra.tokenValues.length;\n            }\n            ++index;\n            break;\n\n        case '{':\n            if (extra.tokenize) {\n                extra.openCurlyToken = extra.tokenValues.length;\n            }\n            state.curlyStack.push('{');\n            ++index;\n            break;\n\n        case '.':\n            ++index;\n            if (source[index] === '.' && source[index + 1] === '.') {\n                // Spread operator: ...\n                index += 2;\n                str = '...';\n            }\n            break;\n\n        case '}':\n            ++index;\n            state.curlyStack.pop();\n            break;\n        case ')':\n        case ';':\n        case ',':\n        case '[':\n        case ']':\n        case ':':\n        case '?':\n        case '~':\n            ++index;\n            break;\n\n        default:\n            // 4-character punctuator.\n            str = source.substr(index, 4);\n            if (str === '>>>=') {\n                index += 4;\n            } else {\n\n                // 3-character punctuators.\n                str = str.substr(0, 3);\n                if (str === '===' || str === '!==' || str === '>>>' ||\n                    str === '<<=' || str === '>>=') {\n                    index += 3;\n                } else {\n\n                    // 2-character punctuators.\n                    str = str.substr(0, 2);\n                    if (str === '&&' || str === '||' || str === '==' || str === '!=' ||\n                        str === '+=' || str === '-=' || str === '*=' || str === '/=' ||\n                        str === '++' || str === '--' || str === '<<' || str === '>>' ||\n                        str === '&=' || str === '|=' || str === '^=' || str === '%=' ||\n                        str === '<=' || str === '>=' || str === '=>') {\n                        index += 2;\n                    } else {\n\n                        // 1-character punctuators.\n                        str = source[index];\n                        if ('<>=!+-*%&|^/'.indexOf(str) >= 0) {\n                            ++index;\n                        }\n                    }\n                }\n            }\n        }\n\n        if (index === token.start) {\n            throwUnexpectedToken();\n        }\n\n        token.end = index;\n        token.value = str;\n        return token;\n    }\n\n    // ECMA-262 11.8.3 Numeric Literals\n\n    function scanHexLiteral(start) {\n        var number = '';\n\n        while (index < length) {\n            if (!isHexDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt('0x' + number, 16),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanBinaryLiteral(start) {\n        var ch, number;\n\n        number = '';\n\n        while (index < length) {\n            ch = source[index];\n            if (ch !== '0' && ch !== '1') {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (number.length === 0) {\n            // only 0b or 0B\n            throwUnexpectedToken();\n        }\n\n        if (index < length) {\n            ch = source.charCodeAt(index);\n            /* istanbul ignore else */\n            if (isIdentifierStart(ch) || isDecimalDigit(ch)) {\n                throwUnexpectedToken();\n            }\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 2),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function scanOctalLiteral(prefix, start) {\n        var number, octal;\n\n        if (isOctalDigit(prefix)) {\n            octal = true;\n            number = '0' + source[index++];\n        } else {\n            octal = false;\n            ++index;\n            number = '';\n        }\n\n        while (index < length) {\n            if (!isOctalDigit(source[index])) {\n                break;\n            }\n            number += source[index++];\n        }\n\n        if (!octal && number.length === 0) {\n            // only 0o or 0O\n            throwUnexpectedToken();\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index)) || isDecimalDigit(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseInt(number, 8),\n            octal: octal,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    function isImplicitOctalLiteral() {\n        var i, ch;\n\n        // Implicit octal, unless there is a non-octal digit.\n        // (Annex B.1.1 on Numeric Literals)\n        for (i = index + 1; i < length; ++i) {\n            ch = source[i];\n            if (ch === '8' || ch === '9') {\n                return false;\n            }\n            if (!isOctalDigit(ch)) {\n                return true;\n            }\n        }\n\n        return true;\n    }\n\n    function scanNumericLiteral() {\n        var number, start, ch;\n\n        ch = source[index];\n        assert(isDecimalDigit(ch.charCodeAt(0)) || (ch === '.'),\n            'Numeric literal must start with a decimal digit or a decimal point');\n\n        start = index;\n        number = '';\n        if (ch !== '.') {\n            number = source[index++];\n            ch = source[index];\n\n            // Hex number starts with '0x'.\n            // Octal number starts with '0'.\n            // Octal number in ES6 starts with '0o'.\n            // Binary number in ES6 starts with '0b'.\n            if (number === '0') {\n                if (ch === 'x' || ch === 'X') {\n                    ++index;\n                    return scanHexLiteral(start);\n                }\n                if (ch === 'b' || ch === 'B') {\n                    ++index;\n                    return scanBinaryLiteral(start);\n                }\n                if (ch === 'o' || ch === 'O') {\n                    return scanOctalLiteral(ch, start);\n                }\n\n                if (isOctalDigit(ch)) {\n                    if (isImplicitOctalLiteral()) {\n                        return scanOctalLiteral(ch, start);\n                    }\n                }\n            }\n\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === '.') {\n            number += source[index++];\n            while (isDecimalDigit(source.charCodeAt(index))) {\n                number += source[index++];\n            }\n            ch = source[index];\n        }\n\n        if (ch === 'e' || ch === 'E') {\n            number += source[index++];\n\n            ch = source[index];\n            if (ch === '+' || ch === '-') {\n                number += source[index++];\n            }\n            if (isDecimalDigit(source.charCodeAt(index))) {\n                while (isDecimalDigit(source.charCodeAt(index))) {\n                    number += source[index++];\n                }\n            } else {\n                throwUnexpectedToken();\n            }\n        }\n\n        if (isIdentifierStart(source.charCodeAt(index))) {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.NumericLiteral,\n            value: parseFloat(number),\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    // ECMA-262 11.8.4 String Literals\n\n    function scanStringLiteral() {\n        var str = '', quote, start, ch, unescaped, octToDec, octal = false;\n\n        quote = source[index];\n        assert((quote === '\\'' || quote === '\"'),\n            'String literal must starts with a quote');\n\n        start = index;\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n\n            if (ch === quote) {\n                quote = '';\n                break;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!ch || !isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            str += scanUnicodeCodePointEscape();\n                        } else {\n                            unescaped = scanHexEscape(ch);\n                            if (!unescaped) {\n                                throw throwUnexpectedToken();\n                            }\n                            str += unescaped;\n                        }\n                        break;\n                    case 'n':\n                        str += '\\n';\n                        break;\n                    case 'r':\n                        str += '\\r';\n                        break;\n                    case 't':\n                        str += '\\t';\n                        break;\n                    case 'b':\n                        str += '\\b';\n                        break;\n                    case 'f':\n                        str += '\\f';\n                        break;\n                    case 'v':\n                        str += '\\x0B';\n                        break;\n                    case '8':\n                    case '9':\n                        str += ch;\n                        tolerateUnexpectedToken();\n                        break;\n\n                    default:\n                        if (isOctalDigit(ch)) {\n                            octToDec = octalToDecimal(ch);\n\n                            octal = octToDec.octal || octal;\n                            str += String.fromCharCode(octToDec.code);\n                        } else {\n                            str += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                break;\n            } else {\n                str += ch;\n            }\n        }\n\n        if (quote !== '') {\n            throwUnexpectedToken();\n        }\n\n        return {\n            type: Token.StringLiteral,\n            value: str,\n            octal: octal,\n            lineNumber: startLineNumber,\n            lineStart: startLineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    // ECMA-262 11.8.6 Template Literal Lexical Components\n\n    function scanTemplate() {\n        var cooked = '', ch, start, rawOffset, terminated, head, tail, restore, unescaped;\n\n        terminated = false;\n        tail = false;\n        start = index;\n        head = (source[index] === '`');\n        rawOffset = 2;\n\n        ++index;\n\n        while (index < length) {\n            ch = source[index++];\n            if (ch === '`') {\n                rawOffset = 1;\n                tail = true;\n                terminated = true;\n                break;\n            } else if (ch === '$') {\n                if (source[index] === '{') {\n                    state.curlyStack.push('${');\n                    ++index;\n                    terminated = true;\n                    break;\n                }\n                cooked += ch;\n            } else if (ch === '\\\\') {\n                ch = source[index++];\n                if (!isLineTerminator(ch.charCodeAt(0))) {\n                    switch (ch) {\n                    case 'n':\n                        cooked += '\\n';\n                        break;\n                    case 'r':\n                        cooked += '\\r';\n                        break;\n                    case 't':\n                        cooked += '\\t';\n                        break;\n                    case 'u':\n                    case 'x':\n                        if (source[index] === '{') {\n                            ++index;\n                            cooked += scanUnicodeCodePointEscape();\n                        } else {\n                            restore = index;\n                            unescaped = scanHexEscape(ch);\n                            if (unescaped) {\n                                cooked += unescaped;\n                            } else {\n                                index = restore;\n                                cooked += ch;\n                            }\n                        }\n                        break;\n                    case 'b':\n                        cooked += '\\b';\n                        break;\n                    case 'f':\n                        cooked += '\\f';\n                        break;\n                    case 'v':\n                        cooked += '\\v';\n                        break;\n\n                    default:\n                        if (ch === '0') {\n                            if (isDecimalDigit(source.charCodeAt(index))) {\n                                // Illegal: \\01 \\02 and so on\n                                throwError(Messages.TemplateOctalLiteral);\n                            }\n                            cooked += '\\0';\n                        } else if (isOctalDigit(ch)) {\n                            // Illegal: \\1 \\2\n                            throwError(Messages.TemplateOctalLiteral);\n                        } else {\n                            cooked += ch;\n                        }\n                        break;\n                    }\n                } else {\n                    ++lineNumber;\n                    if (ch === '\\r' && source[index] === '\\n') {\n                        ++index;\n                    }\n                    lineStart = index;\n                }\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                ++lineNumber;\n                if (ch === '\\r' && source[index] === '\\n') {\n                    ++index;\n                }\n                lineStart = index;\n                cooked += '\\n';\n            } else {\n                cooked += ch;\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken();\n        }\n\n        if (!head) {\n            state.curlyStack.pop();\n        }\n\n        return {\n            type: Token.Template,\n            value: {\n                cooked: cooked,\n                raw: source.slice(start + 1, index - rawOffset)\n            },\n            head: head,\n            tail: tail,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            start: start,\n            end: index\n        };\n    }\n\n    // ECMA-262 11.8.5 Regular Expression Literals\n\n    function testRegExp(pattern, flags) {\n        // The BMP character to use as a replacement for astral symbols when\n        // translating an ES6 \"u\"-flagged pattern to an ES5-compatible\n        // approximation.\n        // Note: replacing with '\\uFFFF' enables false positives in unlikely\n        // scenarios. For example, `[\\u{1044f}-\\u{10440}]` is an invalid\n        // pattern that would not be detected by this substitution.\n        var astralSubstitute = '\\uFFFF',\n            tmp = pattern;\n\n        if (flags.indexOf('u') >= 0) {\n            tmp = tmp\n                // Replace every Unicode escape sequence with the equivalent\n                // BMP character or a constant ASCII code point in the case of\n                // astral symbols. (See the above note on `astralSubstitute`\n                // for more information.)\n                .replace(/\\\\u\\{([0-9a-fA-F]+)\\}|\\\\u([a-fA-F0-9]{4})/g, function ($0, $1, $2) {\n                    var codePoint = parseInt($1 || $2, 16);\n                    if (codePoint > 0x10FFFF) {\n                        throwUnexpectedToken(null, Messages.InvalidRegExp);\n                    }\n                    if (codePoint <= 0xFFFF) {\n                        return String.fromCharCode(codePoint);\n                    }\n                    return astralSubstitute;\n                })\n                // Replace each paired surrogate with a single ASCII symbol to\n                // avoid throwing on regular expressions that are only valid in\n                // combination with the \"u\" flag.\n                .replace(\n                    /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g,\n                    astralSubstitute\n                );\n        }\n\n        // First, detect invalid regular expressions.\n        try {\n            RegExp(tmp);\n        } catch (e) {\n            throwUnexpectedToken(null, Messages.InvalidRegExp);\n        }\n\n        // Return a regular expression object for this pattern-flag pair, or\n        // `null` in case the current environment doesn't support the flags it\n        // uses.\n        try {\n            return new RegExp(pattern, flags);\n        } catch (exception) {\n            return null;\n        }\n    }\n\n    function scanRegExpBody() {\n        var ch, str, classMarker, terminated, body;\n\n        ch = source[index];\n        assert(ch === '/', 'Regular expression literal must start with a slash');\n        str = source[index++];\n\n        classMarker = false;\n        terminated = false;\n        while (index < length) {\n            ch = source[index++];\n            str += ch;\n            if (ch === '\\\\') {\n                ch = source[index++];\n                // ECMA-262 7.8.5\n                if (isLineTerminator(ch.charCodeAt(0))) {\n                    throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n                }\n                str += ch;\n            } else if (isLineTerminator(ch.charCodeAt(0))) {\n                throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n            } else if (classMarker) {\n                if (ch === ']') {\n                    classMarker = false;\n                }\n            } else {\n                if (ch === '/') {\n                    terminated = true;\n                    break;\n                } else if (ch === '[') {\n                    classMarker = true;\n                }\n            }\n        }\n\n        if (!terminated) {\n            throwUnexpectedToken(null, Messages.UnterminatedRegExp);\n        }\n\n        // Exclude leading and trailing slash.\n        body = str.substr(1, str.length - 2);\n        return {\n            value: body,\n            literal: str\n        };\n    }\n\n    function scanRegExpFlags() {\n        var ch, str, flags, restore;\n\n        str = '';\n        flags = '';\n        while (index < length) {\n            ch = source[index];\n            if (!isIdentifierPart(ch.charCodeAt(0))) {\n                break;\n            }\n\n            ++index;\n            if (ch === '\\\\' && index < length) {\n                ch = source[index];\n                if (ch === 'u') {\n                    ++index;\n                    restore = index;\n                    ch = scanHexEscape('u');\n                    if (ch) {\n                        flags += ch;\n                        for (str += '\\\\u'; restore < index; ++restore) {\n                            str += source[restore];\n                        }\n                    } else {\n                        index = restore;\n                        flags += 'u';\n                        str += '\\\\u';\n                    }\n                    tolerateUnexpectedToken();\n                } else {\n                    str += '\\\\';\n                    tolerateUnexpectedToken();\n                }\n            } else {\n                flags += ch;\n                str += ch;\n            }\n        }\n\n        return {\n            value: flags,\n            literal: str\n        };\n    }\n\n    function scanRegExp() {\n        var start, body, flags, value;\n        scanning = true;\n\n        lookahead = null;\n        skipComment();\n        start = index;\n\n        body = scanRegExpBody();\n        flags = scanRegExpFlags();\n        value = testRegExp(body.value, flags.value);\n        scanning = false;\n        if (extra.tokenize) {\n            return {\n                type: Token.RegularExpression,\n                value: value,\n                regex: {\n                    pattern: body.value,\n                    flags: flags.value\n                },\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: start,\n                end: index\n            };\n        }\n\n        return {\n            literal: body.literal + flags.literal,\n            value: value,\n            regex: {\n                pattern: body.value,\n                flags: flags.value\n            },\n            start: start,\n            end: index\n        };\n    }\n\n    function collectRegex() {\n        var pos, loc, regex, token;\n\n        skipComment();\n\n        pos = index;\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        regex = scanRegExp();\n\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        /* istanbul ignore next */\n        if (!extra.tokenize) {\n            // Pop the previous token, which is likely '/' or '/='\n            if (extra.tokens.length > 0) {\n                token = extra.tokens[extra.tokens.length - 1];\n                if (token.range[0] === pos && token.type === 'Punctuator') {\n                    if (token.value === '/' || token.value === '/=') {\n                        extra.tokens.pop();\n                    }\n                }\n            }\n\n            extra.tokens.push({\n                type: 'RegularExpression',\n                value: regex.literal,\n                regex: regex.regex,\n                range: [pos, index],\n                loc: loc\n            });\n        }\n\n        return regex;\n    }\n\n    function isIdentifierName(token) {\n        return token.type === Token.Identifier ||\n            token.type === Token.Keyword ||\n            token.type === Token.BooleanLiteral ||\n            token.type === Token.NullLiteral;\n    }\n\n    // Using the following algorithm:\n    // https://github.com/mozilla/sweet.js/wiki/design\n\n    function advanceSlash() {\n        var regex, previous, check;\n\n        function testKeyword(value) {\n            return value && (value.length > 1) && (value[0] >= 'a') && (value[0] <= 'z');\n        }\n\n        previous = extra.tokenValues[extra.tokens.length - 1];\n        regex = (previous !== null);\n\n        switch (previous) {\n        case 'this':\n        case ']':\n            regex = false;\n            break;\n\n        case ')':\n            check = extra.tokenValues[extra.openParenToken - 1];\n            regex = (check === 'if' || check === 'while' || check === 'for' || check === 'with');\n            break;\n\n        case '}':\n            // Dividing a function by anything makes little sense,\n            // but we have to check for that.\n            regex = false;\n            if (testKeyword(extra.tokenValues[extra.openCurlyToken - 3])) {\n                // Anonymous function, e.g. function(){} /42\n                check = extra.tokenValues[extra.openCurlyToken - 4];\n                regex = check ? (FnExprTokens.indexOf(check) < 0) : false;\n            } else if (testKeyword(extra.tokenValues[extra.openCurlyToken - 4])) {\n                // Named function, e.g. function f(){} /42/\n                check = extra.tokenValues[extra.openCurlyToken - 5];\n                regex = check ? (FnExprTokens.indexOf(check) < 0) : true;\n            }\n        }\n\n        return regex ? collectRegex() : scanPunctuator();\n    }\n\n    function advance() {\n        var cp, token;\n\n        if (index >= length) {\n            return {\n                type: Token.EOF,\n                lineNumber: lineNumber,\n                lineStart: lineStart,\n                start: index,\n                end: index\n            };\n        }\n\n        cp = source.charCodeAt(index);\n\n        if (isIdentifierStart(cp)) {\n            token = scanIdentifier();\n            if (strict && isStrictModeReservedWord(token.value)) {\n                token.type = Token.Keyword;\n            }\n            return token;\n        }\n\n        // Very common: ( and ) and ;\n        if (cp === 0x28 || cp === 0x29 || cp === 0x3B) {\n            return scanPunctuator();\n        }\n\n        // String literal starts with single quote (U+0027) or double quote (U+0022).\n        if (cp === 0x27 || cp === 0x22) {\n            return scanStringLiteral();\n        }\n\n        // Dot (.) U+002E can also start a floating-point number, hence the need\n        // to check the next character.\n        if (cp === 0x2E) {\n            if (isDecimalDigit(source.charCodeAt(index + 1))) {\n                return scanNumericLiteral();\n            }\n            return scanPunctuator();\n        }\n\n        if (isDecimalDigit(cp)) {\n            return scanNumericLiteral();\n        }\n\n        // Slash (/) U+002F can also start a regex.\n        if (extra.tokenize && cp === 0x2F) {\n            return advanceSlash();\n        }\n\n        // Template literals start with ` (U+0060) for template head\n        // or } (U+007D) for template middle or template tail.\n        if (cp === 0x60 || (cp === 0x7D && state.curlyStack[state.curlyStack.length - 1] === '${')) {\n            return scanTemplate();\n        }\n\n        // Possible identifier start in a surrogate pair.\n        if (cp >= 0xD800 && cp < 0xDFFF) {\n            cp = codePointAt(index);\n            if (isIdentifierStart(cp)) {\n                return scanIdentifier();\n            }\n        }\n\n        return scanPunctuator();\n    }\n\n    function collectToken() {\n        var loc, token, value, entry;\n\n        loc = {\n            start: {\n                line: lineNumber,\n                column: index - lineStart\n            }\n        };\n\n        token = advance();\n        loc.end = {\n            line: lineNumber,\n            column: index - lineStart\n        };\n\n        if (token.type !== Token.EOF) {\n            value = source.slice(token.start, token.end);\n            entry = {\n                type: TokenName[token.type],\n                value: value,\n                range: [token.start, token.end],\n                loc: loc\n            };\n            if (token.regex) {\n                entry.regex = {\n                    pattern: token.regex.pattern,\n                    flags: token.regex.flags\n                };\n            }\n            if (extra.tokenValues) {\n                extra.tokenValues.push((entry.type === 'Punctuator' || entry.type === 'Keyword') ? entry.value : null);\n            }\n            if (extra.tokenize) {\n                if (!extra.range) {\n                    delete entry.range;\n                }\n                if (!extra.loc) {\n                    delete entry.loc;\n                }\n                if (extra.delegate) {\n                    entry = extra.delegate(entry);\n                }\n            }\n            extra.tokens.push(entry);\n        }\n\n        return token;\n    }\n\n    function lex() {\n        var token;\n        scanning = true;\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        skipComment();\n\n        token = lookahead;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n        return token;\n    }\n\n    function peek() {\n        scanning = true;\n\n        skipComment();\n\n        lastIndex = index;\n        lastLineNumber = lineNumber;\n        lastLineStart = lineStart;\n\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n\n        lookahead = (typeof extra.tokens !== 'undefined') ? collectToken() : advance();\n        scanning = false;\n    }\n\n    function Position() {\n        this.line = startLineNumber;\n        this.column = startIndex - startLineStart;\n    }\n\n    function SourceLocation() {\n        this.start = new Position();\n        this.end = null;\n    }\n\n    function WrappingSourceLocation(startToken) {\n        this.start = {\n            line: startToken.lineNumber,\n            column: startToken.start - startToken.lineStart\n        };\n        this.end = null;\n    }\n\n    function Node() {\n        if (extra.range) {\n            this.range = [startIndex, 0];\n        }\n        if (extra.loc) {\n            this.loc = new SourceLocation();\n        }\n    }\n\n    function WrappingNode(startToken) {\n        if (extra.range) {\n            this.range = [startToken.start, 0];\n        }\n        if (extra.loc) {\n            this.loc = new WrappingSourceLocation(startToken);\n        }\n    }\n\n    WrappingNode.prototype = Node.prototype = {\n\n        processComment: function () {\n            var lastChild,\n                innerComments,\n                leadingComments,\n                trailingComments,\n                bottomRight = extra.bottomRightStack,\n                i,\n                comment,\n                last = bottomRight[bottomRight.length - 1];\n\n            if (this.type === Syntax.Program) {\n                if (this.body.length > 0) {\n                    return;\n                }\n            }\n            /**\n             * patch innnerComments for properties empty block\n             * `function a() {/** comments **\\/}`\n             */\n\n            if (this.type === Syntax.BlockStatement && this.body.length === 0) {\n                innerComments = [];\n                for (i = extra.leadingComments.length - 1; i >= 0; --i) {\n                    comment = extra.leadingComments[i];\n                    if (this.range[1] >= comment.range[1]) {\n                        innerComments.unshift(comment);\n                        extra.leadingComments.splice(i, 1);\n                        extra.trailingComments.splice(i, 1);\n                    }\n                }\n                if (innerComments.length) {\n                    this.innerComments = innerComments;\n                    //bottomRight.push(this);\n                    return;\n                }\n            }\n\n            if (extra.trailingComments.length > 0) {\n                trailingComments = [];\n                for (i = extra.trailingComments.length - 1; i >= 0; --i) {\n                    comment = extra.trailingComments[i];\n                    if (comment.range[0] >= this.range[1]) {\n                        trailingComments.unshift(comment);\n                        extra.trailingComments.splice(i, 1);\n                    }\n                }\n                extra.trailingComments = [];\n            } else {\n                if (last && last.trailingComments && last.trailingComments[0].range[0] >= this.range[1]) {\n                    trailingComments = last.trailingComments;\n                    delete last.trailingComments;\n                }\n            }\n\n            // Eating the stack.\n            while (last && last.range[0] >= this.range[0]) {\n                lastChild = bottomRight.pop();\n                last = bottomRight[bottomRight.length - 1];\n            }\n\n            if (lastChild) {\n                if (lastChild.leadingComments) {\n                    leadingComments = [];\n                    for (i = lastChild.leadingComments.length - 1; i >= 0; --i) {\n                        comment = lastChild.leadingComments[i];\n                        if (comment.range[1] <= this.range[0]) {\n                            leadingComments.unshift(comment);\n                            lastChild.leadingComments.splice(i, 1);\n                        }\n                    }\n\n                    if (!lastChild.leadingComments.length) {\n                        lastChild.leadingComments = undefined;\n                    }\n                }\n            } else if (extra.leadingComments.length > 0) {\n                leadingComments = [];\n                for (i = extra.leadingComments.length - 1; i >= 0; --i) {\n                    comment = extra.leadingComments[i];\n                    if (comment.range[1] <= this.range[0]) {\n                        leadingComments.unshift(comment);\n                        extra.leadingComments.splice(i, 1);\n                    }\n                }\n            }\n\n\n            if (leadingComments && leadingComments.length > 0) {\n                this.leadingComments = leadingComments;\n            }\n            if (trailingComments && trailingComments.length > 0) {\n                this.trailingComments = trailingComments;\n            }\n\n            bottomRight.push(this);\n        },\n\n        finish: function () {\n            if (extra.range) {\n                this.range[1] = lastIndex;\n            }\n            if (extra.loc) {\n                this.loc.end = {\n                    line: lastLineNumber,\n                    column: lastIndex - lastLineStart\n                };\n                if (extra.source) {\n                    this.loc.source = extra.source;\n                }\n            }\n\n            if (extra.attachComment) {\n                this.processComment();\n            }\n        },\n\n        finishArrayExpression: function (elements) {\n            this.type = Syntax.ArrayExpression;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrayPattern: function (elements) {\n            this.type = Syntax.ArrayPattern;\n            this.elements = elements;\n            this.finish();\n            return this;\n        },\n\n        finishArrowFunctionExpression: function (params, defaults, body, expression) {\n            this.type = Syntax.ArrowFunctionExpression;\n            this.id = null;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = false;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentExpression: function (operator, left, right) {\n            this.type = Syntax.AssignmentExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishAssignmentPattern: function (left, right) {\n            this.type = Syntax.AssignmentPattern;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBinaryExpression: function (operator, left, right) {\n            this.type = (operator === '||' || operator === '&&') ? Syntax.LogicalExpression : Syntax.BinaryExpression;\n            this.operator = operator;\n            this.left = left;\n            this.right = right;\n            this.finish();\n            return this;\n        },\n\n        finishBlockStatement: function (body) {\n            this.type = Syntax.BlockStatement;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishBreakStatement: function (label) {\n            this.type = Syntax.BreakStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishCallExpression: function (callee, args) {\n            this.type = Syntax.CallExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishCatchClause: function (param, body) {\n            this.type = Syntax.CatchClause;\n            this.param = param;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassBody: function (body) {\n            this.type = Syntax.ClassBody;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassDeclaration: function (id, superClass, body) {\n            this.type = Syntax.ClassDeclaration;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishClassExpression: function (id, superClass, body) {\n            this.type = Syntax.ClassExpression;\n            this.id = id;\n            this.superClass = superClass;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishConditionalExpression: function (test, consequent, alternate) {\n            this.type = Syntax.ConditionalExpression;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishContinueStatement: function (label) {\n            this.type = Syntax.ContinueStatement;\n            this.label = label;\n            this.finish();\n            return this;\n        },\n\n        finishDebuggerStatement: function () {\n            this.type = Syntax.DebuggerStatement;\n            this.finish();\n            return this;\n        },\n\n        finishDoWhileStatement: function (body, test) {\n            this.type = Syntax.DoWhileStatement;\n            this.body = body;\n            this.test = test;\n            this.finish();\n            return this;\n        },\n\n        finishEmptyStatement: function () {\n            this.type = Syntax.EmptyStatement;\n            this.finish();\n            return this;\n        },\n\n        finishExpressionStatement: function (expression) {\n            this.type = Syntax.ExpressionStatement;\n            this.expression = expression;\n            this.finish();\n            return this;\n        },\n\n        finishForStatement: function (init, test, update, body) {\n            this.type = Syntax.ForStatement;\n            this.init = init;\n            this.test = test;\n            this.update = update;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishForOfStatement: function (left, right, body) {\n            this.type = Syntax.ForOfStatement;\n            this.left = left;\n            this.right = right;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishForInStatement: function (left, right, body) {\n            this.type = Syntax.ForInStatement;\n            this.left = left;\n            this.right = right;\n            this.body = body;\n            this.each = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionDeclaration: function (id, params, defaults, body, generator) {\n            this.type = Syntax.FunctionDeclaration;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = generator;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishFunctionExpression: function (id, params, defaults, body, generator) {\n            this.type = Syntax.FunctionExpression;\n            this.id = id;\n            this.params = params;\n            this.defaults = defaults;\n            this.body = body;\n            this.generator = generator;\n            this.expression = false;\n            this.finish();\n            return this;\n        },\n\n        finishIdentifier: function (name) {\n            this.type = Syntax.Identifier;\n            this.name = name;\n            this.finish();\n            return this;\n        },\n\n        finishIfStatement: function (test, consequent, alternate) {\n            this.type = Syntax.IfStatement;\n            this.test = test;\n            this.consequent = consequent;\n            this.alternate = alternate;\n            this.finish();\n            return this;\n        },\n\n        finishLabeledStatement: function (label, body) {\n            this.type = Syntax.LabeledStatement;\n            this.label = label;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishLiteral: function (token) {\n            this.type = Syntax.Literal;\n            this.value = token.value;\n            this.raw = source.slice(token.start, token.end);\n            if (token.regex) {\n                this.regex = token.regex;\n            }\n            this.finish();\n            return this;\n        },\n\n        finishMemberExpression: function (accessor, object, property) {\n            this.type = Syntax.MemberExpression;\n            this.computed = accessor === '[';\n            this.object = object;\n            this.property = property;\n            this.finish();\n            return this;\n        },\n\n        finishMetaProperty: function (meta, property) {\n            this.type = Syntax.MetaProperty;\n            this.meta = meta;\n            this.property = property;\n            this.finish();\n            return this;\n        },\n\n        finishNewExpression: function (callee, args) {\n            this.type = Syntax.NewExpression;\n            this.callee = callee;\n            this.arguments = args;\n            this.finish();\n            return this;\n        },\n\n        finishObjectExpression: function (properties) {\n            this.type = Syntax.ObjectExpression;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishObjectPattern: function (properties) {\n            this.type = Syntax.ObjectPattern;\n            this.properties = properties;\n            this.finish();\n            return this;\n        },\n\n        finishPostfixExpression: function (operator, argument) {\n            this.type = Syntax.UpdateExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = false;\n            this.finish();\n            return this;\n        },\n\n        finishProgram: function (body, sourceType) {\n            this.type = Syntax.Program;\n            this.body = body;\n            this.sourceType = sourceType;\n            this.finish();\n            return this;\n        },\n\n        finishProperty: function (kind, key, computed, value, method, shorthand) {\n            this.type = Syntax.Property;\n            this.key = key;\n            this.computed = computed;\n            this.value = value;\n            this.kind = kind;\n            this.method = method;\n            this.shorthand = shorthand;\n            this.finish();\n            return this;\n        },\n\n        finishRestElement: function (argument) {\n            this.type = Syntax.RestElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishReturnStatement: function (argument) {\n            this.type = Syntax.ReturnStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSequenceExpression: function (expressions) {\n            this.type = Syntax.SequenceExpression;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishSpreadElement: function (argument) {\n            this.type = Syntax.SpreadElement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchCase: function (test, consequent) {\n            this.type = Syntax.SwitchCase;\n            this.test = test;\n            this.consequent = consequent;\n            this.finish();\n            return this;\n        },\n\n        finishSuper: function () {\n            this.type = Syntax.Super;\n            this.finish();\n            return this;\n        },\n\n        finishSwitchStatement: function (discriminant, cases) {\n            this.type = Syntax.SwitchStatement;\n            this.discriminant = discriminant;\n            this.cases = cases;\n            this.finish();\n            return this;\n        },\n\n        finishTaggedTemplateExpression: function (tag, quasi) {\n            this.type = Syntax.TaggedTemplateExpression;\n            this.tag = tag;\n            this.quasi = quasi;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateElement: function (value, tail) {\n            this.type = Syntax.TemplateElement;\n            this.value = value;\n            this.tail = tail;\n            this.finish();\n            return this;\n        },\n\n        finishTemplateLiteral: function (quasis, expressions) {\n            this.type = Syntax.TemplateLiteral;\n            this.quasis = quasis;\n            this.expressions = expressions;\n            this.finish();\n            return this;\n        },\n\n        finishThisExpression: function () {\n            this.type = Syntax.ThisExpression;\n            this.finish();\n            return this;\n        },\n\n        finishThrowStatement: function (argument) {\n            this.type = Syntax.ThrowStatement;\n            this.argument = argument;\n            this.finish();\n            return this;\n        },\n\n        finishTryStatement: function (block, handler, finalizer) {\n            this.type = Syntax.TryStatement;\n            this.block = block;\n            this.guardedHandlers = [];\n            this.handlers = handler ? [handler] : [];\n            this.handler = handler;\n            this.finalizer = finalizer;\n            this.finish();\n            return this;\n        },\n\n        finishUnaryExpression: function (operator, argument) {\n            this.type = (operator === '++' || operator === '--') ? Syntax.UpdateExpression : Syntax.UnaryExpression;\n            this.operator = operator;\n            this.argument = argument;\n            this.prefix = true;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclaration: function (declarations) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = 'var';\n            this.finish();\n            return this;\n        },\n\n        finishLexicalDeclaration: function (declarations, kind) {\n            this.type = Syntax.VariableDeclaration;\n            this.declarations = declarations;\n            this.kind = kind;\n            this.finish();\n            return this;\n        },\n\n        finishVariableDeclarator: function (id, init) {\n            this.type = Syntax.VariableDeclarator;\n            this.id = id;\n            this.init = init;\n            this.finish();\n            return this;\n        },\n\n        finishWhileStatement: function (test, body) {\n            this.type = Syntax.WhileStatement;\n            this.test = test;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishWithStatement: function (object, body) {\n            this.type = Syntax.WithStatement;\n            this.object = object;\n            this.body = body;\n            this.finish();\n            return this;\n        },\n\n        finishExportSpecifier: function (local, exported) {\n            this.type = Syntax.ExportSpecifier;\n            this.exported = exported || local;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportDefaultSpecifier: function (local) {\n            this.type = Syntax.ImportDefaultSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishImportNamespaceSpecifier: function (local) {\n            this.type = Syntax.ImportNamespaceSpecifier;\n            this.local = local;\n            this.finish();\n            return this;\n        },\n\n        finishExportNamedDeclaration: function (declaration, specifiers, src) {\n            this.type = Syntax.ExportNamedDeclaration;\n            this.declaration = declaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishExportDefaultDeclaration: function (declaration) {\n            this.type = Syntax.ExportDefaultDeclaration;\n            this.declaration = declaration;\n            this.finish();\n            return this;\n        },\n\n        finishExportAllDeclaration: function (src) {\n            this.type = Syntax.ExportAllDeclaration;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishImportSpecifier: function (local, imported) {\n            this.type = Syntax.ImportSpecifier;\n            this.local = local || imported;\n            this.imported = imported;\n            this.finish();\n            return this;\n        },\n\n        finishImportDeclaration: function (specifiers, src) {\n            this.type = Syntax.ImportDeclaration;\n            this.specifiers = specifiers;\n            this.source = src;\n            this.finish();\n            return this;\n        },\n\n        finishYieldExpression: function (argument, delegate) {\n            this.type = Syntax.YieldExpression;\n            this.argument = argument;\n            this.delegate = delegate;\n            this.finish();\n            return this;\n        }\n    };\n\n\n    function recordError(error) {\n        var e, existing;\n\n        for (e = 0; e < extra.errors.length; e++) {\n            existing = extra.errors[e];\n            // Prevent duplicated error.\n            /* istanbul ignore next */\n            if (existing.index === error.index && existing.message === error.message) {\n                return;\n            }\n        }\n\n        extra.errors.push(error);\n    }\n\n    function constructError(msg, column) {\n        var error = new Error(msg);\n        try {\n            throw error;\n        } catch (base) {\n            /* istanbul ignore else */\n            if (Object.create && Object.defineProperty) {\n                error = Object.create(base);\n                Object.defineProperty(error, 'column', { value: column });\n            }\n        } finally {\n            return error;\n        }\n    }\n\n    function createError(line, pos, description) {\n        var msg, column, error;\n\n        msg = 'Line ' + line + ': ' + description;\n        column = pos - (scanning ? lineStart : lastLineStart) + 1;\n        error = constructError(msg, column);\n        error.lineNumber = line;\n        error.description = description;\n        error.index = pos;\n        return error;\n    }\n\n    // Throw an exception\n\n    function throwError(messageFormat) {\n        var args, msg;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        throw createError(lastLineNumber, lastIndex, msg);\n    }\n\n    function tolerateError(messageFormat) {\n        var args, msg, error;\n\n        args = Array.prototype.slice.call(arguments, 1);\n        /* istanbul ignore next */\n        msg = messageFormat.replace(/%(\\d)/g,\n            function (whole, idx) {\n                assert(idx < args.length, 'Message reference must be in range');\n                return args[idx];\n            }\n        );\n\n        error = createError(lineNumber, lastIndex, msg);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Throw an exception because of the token.\n\n    function unexpectedTokenError(token, message) {\n        var value, msg = message || Messages.UnexpectedToken;\n\n        if (token) {\n            if (!message) {\n                msg = (token.type === Token.EOF) ? Messages.UnexpectedEOS :\n                    (token.type === Token.Identifier) ? Messages.UnexpectedIdentifier :\n                    (token.type === Token.NumericLiteral) ? Messages.UnexpectedNumber :\n                    (token.type === Token.StringLiteral) ? Messages.UnexpectedString :\n                    (token.type === Token.Template) ? Messages.UnexpectedTemplate :\n                    Messages.UnexpectedToken;\n\n                if (token.type === Token.Keyword) {\n                    if (isFutureReservedWord(token.value)) {\n                        msg = Messages.UnexpectedReserved;\n                    } else if (strict && isStrictModeReservedWord(token.value)) {\n                        msg = Messages.StrictReservedWord;\n                    }\n                }\n            }\n\n            value = (token.type === Token.Template) ? token.value.raw : token.value;\n        } else {\n            value = 'ILLEGAL';\n        }\n\n        msg = msg.replace('%0', value);\n\n        return (token && typeof token.lineNumber === 'number') ?\n            createError(token.lineNumber, token.start, msg) :\n            createError(scanning ? lineNumber : lastLineNumber, scanning ? index : lastIndex, msg);\n    }\n\n    function throwUnexpectedToken(token, message) {\n        throw unexpectedTokenError(token, message);\n    }\n\n    function tolerateUnexpectedToken(token, message) {\n        var error = unexpectedTokenError(token, message);\n        if (extra.errors) {\n            recordError(error);\n        } else {\n            throw error;\n        }\n    }\n\n    // Expect the next token to match the specified punctuator.\n    // If not, an exception will be thrown.\n\n    function expect(value) {\n        var token = lex();\n        if (token.type !== Token.Punctuator || token.value !== value) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    /**\n     * @name expectCommaSeparator\n     * @description Quietly expect a comma when in tolerant mode, otherwise delegates\n     * to <code>expect(value)</code>\n     * @since 2.0\n     */\n    function expectCommaSeparator() {\n        var token;\n\n        if (extra.errors) {\n            token = lookahead;\n            if (token.type === Token.Punctuator && token.value === ',') {\n                lex();\n            } else if (token.type === Token.Punctuator && token.value === ';') {\n                lex();\n                tolerateUnexpectedToken(token);\n            } else {\n                tolerateUnexpectedToken(token, Messages.UnexpectedToken);\n            }\n        } else {\n            expect(',');\n        }\n    }\n\n    // Expect the next token to match the specified keyword.\n    // If not, an exception will be thrown.\n\n    function expectKeyword(keyword) {\n        var token = lex();\n        if (token.type !== Token.Keyword || token.value !== keyword) {\n            throwUnexpectedToken(token);\n        }\n    }\n\n    // Return true if the next token matches the specified punctuator.\n\n    function match(value) {\n        return lookahead.type === Token.Punctuator && lookahead.value === value;\n    }\n\n    // Return true if the next token matches the specified keyword\n\n    function matchKeyword(keyword) {\n        return lookahead.type === Token.Keyword && lookahead.value === keyword;\n    }\n\n    // Return true if the next token matches the specified contextual keyword\n    // (where an identifier is sometimes a keyword depending on the context)\n\n    function matchContextualKeyword(keyword) {\n        return lookahead.type === Token.Identifier && lookahead.value === keyword;\n    }\n\n    // Return true if the next token is an assignment operator\n\n    function matchAssign() {\n        var op;\n\n        if (lookahead.type !== Token.Punctuator) {\n            return false;\n        }\n        op = lookahead.value;\n        return op === '=' ||\n            op === '*=' ||\n            op === '/=' ||\n            op === '%=' ||\n            op === '+=' ||\n            op === '-=' ||\n            op === '<<=' ||\n            op === '>>=' ||\n            op === '>>>=' ||\n            op === '&=' ||\n            op === '^=' ||\n            op === '|=';\n    }\n\n    function consumeSemicolon() {\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(startIndex) === 0x3B || match(';')) {\n            lex();\n            return;\n        }\n\n        if (hasLineTerminator) {\n            return;\n        }\n\n        // FIXME(ikarienator): this is seemingly an issue in the previous location info convention.\n        lastIndex = startIndex;\n        lastLineNumber = startLineNumber;\n        lastLineStart = startLineStart;\n\n        if (lookahead.type !== Token.EOF && !match('}')) {\n            throwUnexpectedToken(lookahead);\n        }\n    }\n\n    // Cover grammar support.\n    //\n    // When an assignment expression position starts with an left parenthesis, the determination of the type\n    // of the syntax is to be deferred arbitrarily long until the end of the parentheses pair (plus a lookahead)\n    // or the first comma. This situation also defers the determination of all the expressions nested in the pair.\n    //\n    // There are three productions that can be parsed in a parentheses pair that needs to be determined\n    // after the outermost pair is closed. They are:\n    //\n    //   1. AssignmentExpression\n    //   2. BindingElements\n    //   3. AssignmentTargets\n    //\n    // In order to avoid exponential backtracking, we use two flags to denote if the production can be\n    // binding element or assignment target.\n    //\n    // The three productions have the relationship:\n    //\n    //   BindingElements ⊆ AssignmentTargets ⊆ AssignmentExpression\n    //\n    // with a single exception that CoverInitializedName when used directly in an Expression, generates\n    // an early error. Therefore, we need the third state, firstCoverInitializedNameError, to track the\n    // first usage of CoverInitializedName and report it when we reached the end of the parentheses pair.\n    //\n    // isolateCoverGrammar function runs the given parser function with a new cover grammar context, and it does not\n    // effect the current flags. This means the production the parser parses is only used as an expression. Therefore\n    // the CoverInitializedName check is conducted.\n    //\n    // inheritCoverGrammar function runs the given parse function with a new cover grammar context, and it propagates\n    // the flags outside of the parser. This means the production the parser parses is used as a part of a potential\n    // pattern. The CoverInitializedName check is deferred.\n    function isolateCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        if (firstCoverInitializedNameError !== null) {\n            throwUnexpectedToken(firstCoverInitializedNameError);\n        }\n        isBindingElement = oldIsBindingElement;\n        isAssignmentTarget = oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError;\n        return result;\n    }\n\n    function inheritCoverGrammar(parser) {\n        var oldIsBindingElement = isBindingElement,\n            oldIsAssignmentTarget = isAssignmentTarget,\n            oldFirstCoverInitializedNameError = firstCoverInitializedNameError,\n            result;\n        isBindingElement = true;\n        isAssignmentTarget = true;\n        firstCoverInitializedNameError = null;\n        result = parser();\n        isBindingElement = isBindingElement && oldIsBindingElement;\n        isAssignmentTarget = isAssignmentTarget && oldIsAssignmentTarget;\n        firstCoverInitializedNameError = oldFirstCoverInitializedNameError || firstCoverInitializedNameError;\n        return result;\n    }\n\n    // ECMA-262 13.3.3 Destructuring Binding Patterns\n\n    function parseArrayPattern(params, kind) {\n        var node = new Node(), elements = [], rest, restNode;\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else {\n                if (match('...')) {\n                    restNode = new Node();\n                    lex();\n                    params.push(lookahead);\n                    rest = parseVariableIdentifier(kind);\n                    elements.push(restNode.finishRestElement(rest));\n                    break;\n                } else {\n                    elements.push(parsePatternWithDefault(params, kind));\n                }\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n\n        }\n\n        expect(']');\n\n        return node.finishArrayPattern(elements);\n    }\n\n    function parsePropertyPattern(params, kind) {\n        var node = new Node(), key, keyToken, computed = match('['), init;\n        if (lookahead.type === Token.Identifier) {\n            keyToken = lookahead;\n            key = parseVariableIdentifier();\n            if (match('=')) {\n                params.push(keyToken);\n                lex();\n                init = parseAssignmentExpression();\n\n                return node.finishProperty(\n                    'init', key, false,\n                    new WrappingNode(keyToken).finishAssignmentPattern(key, init), false, false);\n            } else if (!match(':')) {\n                params.push(keyToken);\n                return node.finishProperty('init', key, false, key, false, true);\n            }\n        } else {\n            key = parseObjectPropertyKey();\n        }\n        expect(':');\n        init = parsePatternWithDefault(params, kind);\n        return node.finishProperty('init', key, computed, init, false, false);\n    }\n\n    function parseObjectPattern(params, kind) {\n        var node = new Node(), properties = [];\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parsePropertyPattern(params, kind));\n            if (!match('}')) {\n                expect(',');\n            }\n        }\n\n        lex();\n\n        return node.finishObjectPattern(properties);\n    }\n\n    function parsePattern(params, kind) {\n        if (match('[')) {\n            return parseArrayPattern(params, kind);\n        } else if (match('{')) {\n            return parseObjectPattern(params, kind);\n        } else if (matchKeyword('let')) {\n            if (kind === 'const' || kind === 'let') {\n                tolerateUnexpectedToken(lookahead, Messages.UnexpectedToken);\n            }\n        }\n\n        params.push(lookahead);\n        return parseVariableIdentifier(kind);\n    }\n\n    function parsePatternWithDefault(params, kind) {\n        var startToken = lookahead, pattern, previousAllowYield, right;\n        pattern = parsePattern(params, kind);\n        if (match('=')) {\n            lex();\n            previousAllowYield = state.allowYield;\n            state.allowYield = true;\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            state.allowYield = previousAllowYield;\n            pattern = new WrappingNode(startToken).finishAssignmentPattern(pattern, right);\n        }\n        return pattern;\n    }\n\n    // ECMA-262 12.2.5 Array Initializer\n\n    function parseArrayInitializer() {\n        var elements = [], node = new Node(), restSpread;\n\n        expect('[');\n\n        while (!match(']')) {\n            if (match(',')) {\n                lex();\n                elements.push(null);\n            } else if (match('...')) {\n                restSpread = new Node();\n                lex();\n                restSpread.finishSpreadElement(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    isAssignmentTarget = isBindingElement = false;\n                    expect(',');\n                }\n                elements.push(restSpread);\n            } else {\n                elements.push(inheritCoverGrammar(parseAssignmentExpression));\n\n                if (!match(']')) {\n                    expect(',');\n                }\n            }\n        }\n\n        lex();\n\n        return node.finishArrayExpression(elements);\n    }\n\n    // ECMA-262 12.2.6 Object Initializer\n\n    function parsePropertyFunction(node, paramInfo, isGenerator) {\n        var previousStrict, body;\n\n        isAssignmentTarget = isBindingElement = false;\n\n        previousStrict = strict;\n        body = isolateCoverGrammar(parseFunctionSourceElements);\n\n        if (strict && paramInfo.firstRestricted) {\n            tolerateUnexpectedToken(paramInfo.firstRestricted, paramInfo.message);\n        }\n        if (strict && paramInfo.stricted) {\n            tolerateUnexpectedToken(paramInfo.stricted, paramInfo.message);\n        }\n\n        strict = previousStrict;\n        return node.finishFunctionExpression(null, paramInfo.params, paramInfo.defaults, body, isGenerator);\n    }\n\n    function parsePropertyMethodFunction() {\n        var params, method, node = new Node(),\n            previousAllowYield = state.allowYield;\n\n        state.allowYield = false;\n        params = parseParams();\n        state.allowYield = previousAllowYield;\n\n        state.allowYield = false;\n        method = parsePropertyFunction(node, params, false);\n        state.allowYield = previousAllowYield;\n\n        return method;\n    }\n\n    function parseObjectPropertyKey() {\n        var token, node = new Node(), expr;\n\n        token = lex();\n\n        // Note: This function is called only from parseObjectProperty(), where\n        // EOF and Punctuator tokens are already filtered out.\n\n        switch (token.type) {\n        case Token.StringLiteral:\n        case Token.NumericLiteral:\n            if (strict && token.octal) {\n                tolerateUnexpectedToken(token, Messages.StrictOctalLiteral);\n            }\n            return node.finishLiteral(token);\n        case Token.Identifier:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.Keyword:\n            return node.finishIdentifier(token.value);\n        case Token.Punctuator:\n            if (token.value === '[') {\n                expr = isolateCoverGrammar(parseAssignmentExpression);\n                expect(']');\n                return expr;\n            }\n            break;\n        }\n        throwUnexpectedToken(token);\n    }\n\n    function lookaheadPropertyName() {\n        switch (lookahead.type) {\n        case Token.Identifier:\n        case Token.StringLiteral:\n        case Token.BooleanLiteral:\n        case Token.NullLiteral:\n        case Token.NumericLiteral:\n        case Token.Keyword:\n            return true;\n        case Token.Punctuator:\n            return lookahead.value === '[';\n        }\n        return false;\n    }\n\n    // This function is to try to parse a MethodDefinition as defined in 14.3. But in the case of object literals,\n    // it might be called at a position where there is in fact a short hand identifier pattern or a data property.\n    // This can only be determined after we consumed up to the left parentheses.\n    //\n    // In order to avoid back tracking, it returns `null` if the position is not a MethodDefinition and the caller\n    // is responsible to visit other options.\n    function tryParseMethodDefinition(token, key, computed, node) {\n        var value, options, methodNode, params,\n            previousAllowYield = state.allowYield;\n\n        if (token.type === Token.Identifier) {\n            // check for `get` and `set`;\n\n            if (token.value === 'get' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n                expect(')');\n\n                state.allowYield = false;\n                value = parsePropertyFunction(methodNode, {\n                    params: [],\n                    defaults: [],\n                    stricted: null,\n                    firstRestricted: null,\n                    message: null\n                }, false);\n                state.allowYield = previousAllowYield;\n\n                return node.finishProperty('get', key, computed, value, false, false);\n            } else if (token.value === 'set' && lookaheadPropertyName()) {\n                computed = match('[');\n                key = parseObjectPropertyKey();\n                methodNode = new Node();\n                expect('(');\n\n                options = {\n                    params: [],\n                    defaultCount: 0,\n                    defaults: [],\n                    firstRestricted: null,\n                    paramSet: {}\n                };\n                if (match(')')) {\n                    tolerateUnexpectedToken(lookahead);\n                } else {\n                    state.allowYield = false;\n                    parseParam(options);\n                    state.allowYield = previousAllowYield;\n                    if (options.defaultCount === 0) {\n                        options.defaults = [];\n                    }\n                }\n                expect(')');\n\n                state.allowYield = false;\n                value = parsePropertyFunction(methodNode, options, false);\n                state.allowYield = previousAllowYield;\n\n                return node.finishProperty('set', key, computed, value, false, false);\n            }\n        } else if (token.type === Token.Punctuator && token.value === '*' && lookaheadPropertyName()) {\n            computed = match('[');\n            key = parseObjectPropertyKey();\n            methodNode = new Node();\n\n            state.allowYield = true;\n            params = parseParams();\n            state.allowYield = previousAllowYield;\n\n            state.allowYield = false;\n            value = parsePropertyFunction(methodNode, params, true);\n            state.allowYield = previousAllowYield;\n\n            return node.finishProperty('init', key, computed, value, true, false);\n        }\n\n        if (key && match('(')) {\n            value = parsePropertyMethodFunction();\n            return node.finishProperty('init', key, computed, value, true, false);\n        }\n\n        // Not a MethodDefinition.\n        return null;\n    }\n\n    function parseObjectProperty(hasProto) {\n        var token = lookahead, node = new Node(), computed, key, maybeMethod, proto, value;\n\n        computed = match('[');\n        if (match('*')) {\n            lex();\n        } else {\n            key = parseObjectPropertyKey();\n        }\n        maybeMethod = tryParseMethodDefinition(token, key, computed, node);\n        if (maybeMethod) {\n            return maybeMethod;\n        }\n\n        if (!key) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        // Check for duplicated __proto__\n        if (!computed) {\n            proto = (key.type === Syntax.Identifier && key.name === '__proto__') ||\n                (key.type === Syntax.Literal && key.value === '__proto__');\n            if (hasProto.value && proto) {\n                tolerateError(Messages.DuplicateProtoProperty);\n            }\n            hasProto.value |= proto;\n        }\n\n        if (match(':')) {\n            lex();\n            value = inheritCoverGrammar(parseAssignmentExpression);\n            return node.finishProperty('init', key, computed, value, false, false);\n        }\n\n        if (token.type === Token.Identifier) {\n            if (match('=')) {\n                firstCoverInitializedNameError = lookahead;\n                lex();\n                value = isolateCoverGrammar(parseAssignmentExpression);\n                return node.finishProperty('init', key, computed,\n                    new WrappingNode(token).finishAssignmentPattern(key, value), false, true);\n            }\n            return node.finishProperty('init', key, computed, key, false, true);\n        }\n\n        throwUnexpectedToken(lookahead);\n    }\n\n    function parseObjectInitializer() {\n        var properties = [], hasProto = {value: false}, node = new Node();\n\n        expect('{');\n\n        while (!match('}')) {\n            properties.push(parseObjectProperty(hasProto));\n\n            if (!match('}')) {\n                expectCommaSeparator();\n            }\n        }\n\n        expect('}');\n\n        return node.finishObjectExpression(properties);\n    }\n\n    function reinterpretExpressionAsPattern(expr) {\n        var i;\n        switch (expr.type) {\n        case Syntax.Identifier:\n        case Syntax.MemberExpression:\n        case Syntax.RestElement:\n        case Syntax.AssignmentPattern:\n            break;\n        case Syntax.SpreadElement:\n            expr.type = Syntax.RestElement;\n            reinterpretExpressionAsPattern(expr.argument);\n            break;\n        case Syntax.ArrayExpression:\n            expr.type = Syntax.ArrayPattern;\n            for (i = 0; i < expr.elements.length; i++) {\n                if (expr.elements[i] !== null) {\n                    reinterpretExpressionAsPattern(expr.elements[i]);\n                }\n            }\n            break;\n        case Syntax.ObjectExpression:\n            expr.type = Syntax.ObjectPattern;\n            for (i = 0; i < expr.properties.length; i++) {\n                reinterpretExpressionAsPattern(expr.properties[i].value);\n            }\n            break;\n        case Syntax.AssignmentExpression:\n            expr.type = Syntax.AssignmentPattern;\n            reinterpretExpressionAsPattern(expr.left);\n            break;\n        default:\n            // Allow other node type for tolerant parsing.\n            break;\n        }\n    }\n\n    // ECMA-262 12.2.9 Template Literals\n\n    function parseTemplateElement(option) {\n        var node, token;\n\n        if (lookahead.type !== Token.Template || (option.head && !lookahead.head)) {\n            throwUnexpectedToken();\n        }\n\n        node = new Node();\n        token = lex();\n\n        return node.finishTemplateElement({ raw: token.value.raw, cooked: token.value.cooked }, token.tail);\n    }\n\n    function parseTemplateLiteral() {\n        var quasi, quasis, expressions, node = new Node();\n\n        quasi = parseTemplateElement({ head: true });\n        quasis = [quasi];\n        expressions = [];\n\n        while (!quasi.tail) {\n            expressions.push(parseExpression());\n            quasi = parseTemplateElement({ head: false });\n            quasis.push(quasi);\n        }\n\n        return node.finishTemplateLiteral(quasis, expressions);\n    }\n\n    // ECMA-262 12.2.10 The Grouping Operator\n\n    function parseGroupExpression() {\n        var expr, expressions, startToken, i, params = [];\n\n        expect('(');\n\n        if (match(')')) {\n            lex();\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: [],\n                rawParams: []\n            };\n        }\n\n        startToken = lookahead;\n        if (match('...')) {\n            expr = parseRestElement(params);\n            expect(')');\n            if (!match('=>')) {\n                expect('=>');\n            }\n            return {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: [expr]\n            };\n        }\n\n        isBindingElement = true;\n        expr = inheritCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            isAssignmentTarget = false;\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n\n                if (match('...')) {\n                    if (!isBindingElement) {\n                        throwUnexpectedToken(lookahead);\n                    }\n                    expressions.push(parseRestElement(params));\n                    expect(')');\n                    if (!match('=>')) {\n                        expect('=>');\n                    }\n                    isBindingElement = false;\n                    for (i = 0; i < expressions.length; i++) {\n                        reinterpretExpressionAsPattern(expressions[i]);\n                    }\n                    return {\n                        type: PlaceHolders.ArrowParameterPlaceHolder,\n                        params: expressions\n                    };\n                }\n\n                expressions.push(inheritCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n\n        expect(')');\n\n        if (match('=>')) {\n            if (expr.type === Syntax.Identifier && expr.name === 'yield') {\n                return {\n                    type: PlaceHolders.ArrowParameterPlaceHolder,\n                    params: [expr]\n                };\n            }\n\n            if (!isBindingElement) {\n                throwUnexpectedToken(lookahead);\n            }\n\n            if (expr.type === Syntax.SequenceExpression) {\n                for (i = 0; i < expr.expressions.length; i++) {\n                    reinterpretExpressionAsPattern(expr.expressions[i]);\n                }\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            expr = {\n                type: PlaceHolders.ArrowParameterPlaceHolder,\n                params: expr.type === Syntax.SequenceExpression ? expr.expressions : [expr]\n            };\n        }\n        isBindingElement = false;\n        return expr;\n    }\n\n\n    // ECMA-262 12.2 Primary Expressions\n\n    function parsePrimaryExpression() {\n        var type, token, expr, node;\n\n        if (match('(')) {\n            isBindingElement = false;\n            return inheritCoverGrammar(parseGroupExpression);\n        }\n\n        if (match('[')) {\n            return inheritCoverGrammar(parseArrayInitializer);\n        }\n\n        if (match('{')) {\n            return inheritCoverGrammar(parseObjectInitializer);\n        }\n\n        type = lookahead.type;\n        node = new Node();\n\n        if (type === Token.Identifier) {\n            if (state.sourceType === 'module' && lookahead.value === 'await') {\n                tolerateUnexpectedToken(lookahead);\n            }\n            expr = node.finishIdentifier(lex().value);\n        } else if (type === Token.StringLiteral || type === Token.NumericLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            if (strict && lookahead.octal) {\n                tolerateUnexpectedToken(lookahead, Messages.StrictOctalLiteral);\n            }\n            expr = node.finishLiteral(lex());\n        } else if (type === Token.Keyword) {\n            if (!strict && state.allowYield && matchKeyword('yield')) {\n                return parseNonComputedProperty();\n            }\n            if (!strict && matchKeyword('let')) {\n                return node.finishIdentifier(lex().value);\n            }\n            isAssignmentTarget = isBindingElement = false;\n            if (matchKeyword('function')) {\n                return parseFunctionExpression();\n            }\n            if (matchKeyword('this')) {\n                lex();\n                return node.finishThisExpression();\n            }\n            if (matchKeyword('class')) {\n                return parseClassExpression();\n            }\n            throwUnexpectedToken(lex());\n        } else if (type === Token.BooleanLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = (token.value === 'true');\n            expr = node.finishLiteral(token);\n        } else if (type === Token.NullLiteral) {\n            isAssignmentTarget = isBindingElement = false;\n            token = lex();\n            token.value = null;\n            expr = node.finishLiteral(token);\n        } else if (match('/') || match('/=')) {\n            isAssignmentTarget = isBindingElement = false;\n            index = startIndex;\n\n            if (typeof extra.tokens !== 'undefined') {\n                token = collectRegex();\n            } else {\n                token = scanRegExp();\n            }\n            lex();\n            expr = node.finishLiteral(token);\n        } else if (type === Token.Template) {\n            expr = parseTemplateLiteral();\n        } else {\n            throwUnexpectedToken(lex());\n        }\n\n        return expr;\n    }\n\n    // ECMA-262 12.3 Left-Hand-Side Expressions\n\n    function parseArguments() {\n        var args = [], expr;\n\n        expect('(');\n\n        if (!match(')')) {\n            while (startIndex < length) {\n                if (match('...')) {\n                    expr = new Node();\n                    lex();\n                    expr.finishSpreadElement(isolateCoverGrammar(parseAssignmentExpression));\n                } else {\n                    expr = isolateCoverGrammar(parseAssignmentExpression);\n                }\n                args.push(expr);\n                if (match(')')) {\n                    break;\n                }\n                expectCommaSeparator();\n            }\n        }\n\n        expect(')');\n\n        return args;\n    }\n\n    function parseNonComputedProperty() {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (!isIdentifierName(token)) {\n            throwUnexpectedToken(token);\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseNonComputedMember() {\n        expect('.');\n\n        return parseNonComputedProperty();\n    }\n\n    function parseComputedMember() {\n        var expr;\n\n        expect('[');\n\n        expr = isolateCoverGrammar(parseExpression);\n\n        expect(']');\n\n        return expr;\n    }\n\n    // ECMA-262 12.3.3 The new Operator\n\n    function parseNewExpression() {\n        var callee, args, node = new Node();\n\n        expectKeyword('new');\n\n        if (match('.')) {\n            lex();\n            if (lookahead.type === Token.Identifier && lookahead.value === 'target') {\n                if (state.inFunctionBody) {\n                    lex();\n                    return node.finishMetaProperty('new', 'target');\n                }\n            }\n            throwUnexpectedToken(lookahead);\n        }\n\n        callee = isolateCoverGrammar(parseLeftHandSideExpression);\n        args = match('(') ? parseArguments() : [];\n\n        isAssignmentTarget = isBindingElement = false;\n\n        return node.finishNewExpression(callee, args);\n    }\n\n    // ECMA-262 12.3.4 Function Calls\n\n    function parseLeftHandSideExpressionAllowCall() {\n        var quasi, expr, args, property, startToken, previousAllowIn = state.allowIn;\n\n        startToken = lookahead;\n        state.allowIn = true;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('(') && !match('.') && !match('[')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (match('(')) {\n                isBindingElement = false;\n                isAssignmentTarget = false;\n                args = parseArguments();\n                expr = new WrappingNode(startToken).finishCallExpression(expr, args);\n            } else if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        state.allowIn = previousAllowIn;\n\n        return expr;\n    }\n\n    // ECMA-262 12.3 Left-Hand-Side Expressions\n\n    function parseLeftHandSideExpression() {\n        var quasi, expr, property, startToken;\n        assert(state.allowIn, 'callee of new expression always allow in keyword.');\n\n        startToken = lookahead;\n\n        if (matchKeyword('super') && state.inFunctionBody) {\n            expr = new Node();\n            lex();\n            expr = expr.finishSuper();\n            if (!match('[') && !match('.')) {\n                throwUnexpectedToken(lookahead);\n            }\n        } else {\n            expr = inheritCoverGrammar(matchKeyword('new') ? parseNewExpression : parsePrimaryExpression);\n        }\n\n        for (;;) {\n            if (match('[')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('[', expr, property);\n            } else if (match('.')) {\n                isBindingElement = false;\n                isAssignmentTarget = true;\n                property = parseNonComputedMember();\n                expr = new WrappingNode(startToken).finishMemberExpression('.', expr, property);\n            } else if (lookahead.type === Token.Template && lookahead.head) {\n                quasi = parseTemplateLiteral();\n                expr = new WrappingNode(startToken).finishTaggedTemplateExpression(expr, quasi);\n            } else {\n                break;\n            }\n        }\n        return expr;\n    }\n\n    // ECMA-262 12.4 Postfix Expressions\n\n    function parsePostfixExpression() {\n        var expr, token, startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseLeftHandSideExpressionAllowCall);\n\n        if (!hasLineTerminator && lookahead.type === Token.Punctuator) {\n            if (match('++') || match('--')) {\n                // ECMA-262 11.3.1, 11.3.2\n                if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                    tolerateError(Messages.StrictLHSPostfix);\n                }\n\n                if (!isAssignmentTarget) {\n                    tolerateError(Messages.InvalidLHSInAssignment);\n                }\n\n                isAssignmentTarget = isBindingElement = false;\n\n                token = lex();\n                expr = new WrappingNode(startToken).finishPostfixExpression(token.value, expr);\n            }\n        }\n\n        return expr;\n    }\n\n    // ECMA-262 12.5 Unary Operators\n\n    function parseUnaryExpression() {\n        var token, expr, startToken;\n\n        if (lookahead.type !== Token.Punctuator && lookahead.type !== Token.Keyword) {\n            expr = parsePostfixExpression();\n        } else if (match('++') || match('--')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            // ECMA-262 11.4.4, 11.4.5\n            if (strict && expr.type === Syntax.Identifier && isRestrictedWord(expr.name)) {\n                tolerateError(Messages.StrictLHSPrefix);\n            }\n\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (match('+') || match('-') || match('~') || match('!')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            isAssignmentTarget = isBindingElement = false;\n        } else if (matchKeyword('delete') || matchKeyword('void') || matchKeyword('typeof')) {\n            startToken = lookahead;\n            token = lex();\n            expr = inheritCoverGrammar(parseUnaryExpression);\n            expr = new WrappingNode(startToken).finishUnaryExpression(token.value, expr);\n            if (strict && expr.operator === 'delete' && expr.argument.type === Syntax.Identifier) {\n                tolerateError(Messages.StrictDelete);\n            }\n            isAssignmentTarget = isBindingElement = false;\n        } else {\n            expr = parsePostfixExpression();\n        }\n\n        return expr;\n    }\n\n    function binaryPrecedence(token, allowIn) {\n        var prec = 0;\n\n        if (token.type !== Token.Punctuator && token.type !== Token.Keyword) {\n            return 0;\n        }\n\n        switch (token.value) {\n        case '||':\n            prec = 1;\n            break;\n\n        case '&&':\n            prec = 2;\n            break;\n\n        case '|':\n            prec = 3;\n            break;\n\n        case '^':\n            prec = 4;\n            break;\n\n        case '&':\n            prec = 5;\n            break;\n\n        case '==':\n        case '!=':\n        case '===':\n        case '!==':\n            prec = 6;\n            break;\n\n        case '<':\n        case '>':\n        case '<=':\n        case '>=':\n        case 'instanceof':\n            prec = 7;\n            break;\n\n        case 'in':\n            prec = allowIn ? 7 : 0;\n            break;\n\n        case '<<':\n        case '>>':\n        case '>>>':\n            prec = 8;\n            break;\n\n        case '+':\n        case '-':\n            prec = 9;\n            break;\n\n        case '*':\n        case '/':\n        case '%':\n            prec = 11;\n            break;\n\n        default:\n            break;\n        }\n\n        return prec;\n    }\n\n    // ECMA-262 12.6 Multiplicative Operators\n    // ECMA-262 12.7 Additive Operators\n    // ECMA-262 12.8 Bitwise Shift Operators\n    // ECMA-262 12.9 Relational Operators\n    // ECMA-262 12.10 Equality Operators\n    // ECMA-262 12.11 Binary Bitwise Operators\n    // ECMA-262 12.12 Binary Logical Operators\n\n    function parseBinaryExpression() {\n        var marker, markers, expr, token, prec, stack, right, operator, left, i;\n\n        marker = lookahead;\n        left = inheritCoverGrammar(parseUnaryExpression);\n\n        token = lookahead;\n        prec = binaryPrecedence(token, state.allowIn);\n        if (prec === 0) {\n            return left;\n        }\n        isAssignmentTarget = isBindingElement = false;\n        token.prec = prec;\n        lex();\n\n        markers = [marker, lookahead];\n        right = isolateCoverGrammar(parseUnaryExpression);\n\n        stack = [left, token, right];\n\n        while ((prec = binaryPrecedence(lookahead, state.allowIn)) > 0) {\n\n            // Reduce: make a binary expression from the three topmost entries.\n            while ((stack.length > 2) && (prec <= stack[stack.length - 2].prec)) {\n                right = stack.pop();\n                operator = stack.pop().value;\n                left = stack.pop();\n                markers.pop();\n                expr = new WrappingNode(markers[markers.length - 1]).finishBinaryExpression(operator, left, right);\n                stack.push(expr);\n            }\n\n            // Shift.\n            token = lex();\n            token.prec = prec;\n            stack.push(token);\n            markers.push(lookahead);\n            expr = isolateCoverGrammar(parseUnaryExpression);\n            stack.push(expr);\n        }\n\n        // Final reduce to clean-up the stack.\n        i = stack.length - 1;\n        expr = stack[i];\n        markers.pop();\n        while (i > 1) {\n            expr = new WrappingNode(markers.pop()).finishBinaryExpression(stack[i - 1].value, stack[i - 2], expr);\n            i -= 2;\n        }\n\n        return expr;\n    }\n\n\n    // ECMA-262 12.13 Conditional Operator\n\n    function parseConditionalExpression() {\n        var expr, previousAllowIn, consequent, alternate, startToken;\n\n        startToken = lookahead;\n\n        expr = inheritCoverGrammar(parseBinaryExpression);\n        if (match('?')) {\n            lex();\n            previousAllowIn = state.allowIn;\n            state.allowIn = true;\n            consequent = isolateCoverGrammar(parseAssignmentExpression);\n            state.allowIn = previousAllowIn;\n            expect(':');\n            alternate = isolateCoverGrammar(parseAssignmentExpression);\n\n            expr = new WrappingNode(startToken).finishConditionalExpression(expr, consequent, alternate);\n            isAssignmentTarget = isBindingElement = false;\n        }\n\n        return expr;\n    }\n\n    // ECMA-262 14.2 Arrow Function Definitions\n\n    function parseConciseBody() {\n        if (match('{')) {\n            return parseFunctionSourceElements();\n        }\n        return isolateCoverGrammar(parseAssignmentExpression);\n    }\n\n    function checkPatternParam(options, param) {\n        var i;\n        switch (param.type) {\n        case Syntax.Identifier:\n            validateParam(options, param, param.name);\n            break;\n        case Syntax.RestElement:\n            checkPatternParam(options, param.argument);\n            break;\n        case Syntax.AssignmentPattern:\n            checkPatternParam(options, param.left);\n            break;\n        case Syntax.ArrayPattern:\n            for (i = 0; i < param.elements.length; i++) {\n                if (param.elements[i] !== null) {\n                    checkPatternParam(options, param.elements[i]);\n                }\n            }\n            break;\n        case Syntax.YieldExpression:\n            break;\n        default:\n            assert(param.type === Syntax.ObjectPattern, 'Invalid type');\n            for (i = 0; i < param.properties.length; i++) {\n                checkPatternParam(options, param.properties[i].value);\n            }\n            break;\n        }\n    }\n    function reinterpretAsCoverFormalsList(expr) {\n        var i, len, param, params, defaults, defaultCount, options, token;\n\n        defaults = [];\n        defaultCount = 0;\n        params = [expr];\n\n        switch (expr.type) {\n        case Syntax.Identifier:\n            break;\n        case PlaceHolders.ArrowParameterPlaceHolder:\n            params = expr.params;\n            break;\n        default:\n            return null;\n        }\n\n        options = {\n            paramSet: {}\n        };\n\n        for (i = 0, len = params.length; i < len; i += 1) {\n            param = params[i];\n            switch (param.type) {\n            case Syntax.AssignmentPattern:\n                params[i] = param.left;\n                if (param.right.type === Syntax.YieldExpression) {\n                    if (param.right.argument) {\n                        throwUnexpectedToken(lookahead);\n                    }\n                    param.right.type = Syntax.Identifier;\n                    param.right.name = 'yield';\n                    delete param.right.argument;\n                    delete param.right.delegate;\n                }\n                defaults.push(param.right);\n                ++defaultCount;\n                checkPatternParam(options, param.left);\n                break;\n            default:\n                checkPatternParam(options, param);\n                params[i] = param;\n                defaults.push(null);\n                break;\n            }\n        }\n\n        if (strict || !state.allowYield) {\n            for (i = 0, len = params.length; i < len; i += 1) {\n                param = params[i];\n                if (param.type === Syntax.YieldExpression) {\n                    throwUnexpectedToken(lookahead);\n                }\n            }\n        }\n\n        if (options.message === Messages.StrictParamDupe) {\n            token = strict ? options.stricted : options.firstRestricted;\n            throwUnexpectedToken(token, options.message);\n        }\n\n        if (defaultCount === 0) {\n            defaults = [];\n        }\n\n        return {\n            params: params,\n            defaults: defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseArrowFunctionExpression(options, node) {\n        var previousStrict, previousAllowYield, body;\n\n        if (hasLineTerminator) {\n            tolerateUnexpectedToken(lookahead);\n        }\n        expect('=>');\n\n        previousStrict = strict;\n        previousAllowYield = state.allowYield;\n        state.allowYield = true;\n\n        body = parseConciseBody();\n\n        if (strict && options.firstRestricted) {\n            throwUnexpectedToken(options.firstRestricted, options.message);\n        }\n        if (strict && options.stricted) {\n            tolerateUnexpectedToken(options.stricted, options.message);\n        }\n\n        strict = previousStrict;\n        state.allowYield = previousAllowYield;\n\n        return node.finishArrowFunctionExpression(options.params, options.defaults, body, body.type !== Syntax.BlockStatement);\n    }\n\n    // ECMA-262 14.4 Yield expression\n\n    function parseYieldExpression() {\n        var argument, expr, delegate, previousAllowYield;\n\n        argument = null;\n        expr = new Node();\n        delegate = false;\n\n        expectKeyword('yield');\n\n        if (!hasLineTerminator) {\n            previousAllowYield = state.allowYield;\n            state.allowYield = false;\n            delegate = match('*');\n            if (delegate) {\n                lex();\n                argument = parseAssignmentExpression();\n            } else {\n                if (!match(';') && !match('}') && !match(')') && lookahead.type !== Token.EOF) {\n                    argument = parseAssignmentExpression();\n                }\n            }\n            state.allowYield = previousAllowYield;\n        }\n\n        return expr.finishYieldExpression(argument, delegate);\n    }\n\n    // ECMA-262 12.14 Assignment Operators\n\n    function parseAssignmentExpression() {\n        var token, expr, right, list, startToken;\n\n        startToken = lookahead;\n        token = lookahead;\n\n        if (!state.allowYield && matchKeyword('yield')) {\n            return parseYieldExpression();\n        }\n\n        expr = parseConditionalExpression();\n\n        if (expr.type === PlaceHolders.ArrowParameterPlaceHolder || match('=>')) {\n            isAssignmentTarget = isBindingElement = false;\n            list = reinterpretAsCoverFormalsList(expr);\n\n            if (list) {\n                firstCoverInitializedNameError = null;\n                return parseArrowFunctionExpression(list, new WrappingNode(startToken));\n            }\n\n            return expr;\n        }\n\n        if (matchAssign()) {\n            if (!isAssignmentTarget) {\n                tolerateError(Messages.InvalidLHSInAssignment);\n            }\n\n            // ECMA-262 12.1.1\n            if (strict && expr.type === Syntax.Identifier) {\n                if (isRestrictedWord(expr.name)) {\n                    tolerateUnexpectedToken(token, Messages.StrictLHSAssignment);\n                }\n                if (isStrictModeReservedWord(expr.name)) {\n                    tolerateUnexpectedToken(token, Messages.StrictReservedWord);\n                }\n            }\n\n            if (!match('=')) {\n                isAssignmentTarget = isBindingElement = false;\n            } else {\n                reinterpretExpressionAsPattern(expr);\n            }\n\n            token = lex();\n            right = isolateCoverGrammar(parseAssignmentExpression);\n            expr = new WrappingNode(startToken).finishAssignmentExpression(token.value, expr, right);\n            firstCoverInitializedNameError = null;\n        }\n\n        return expr;\n    }\n\n    // ECMA-262 12.15 Comma Operator\n\n    function parseExpression() {\n        var expr, startToken = lookahead, expressions;\n\n        expr = isolateCoverGrammar(parseAssignmentExpression);\n\n        if (match(',')) {\n            expressions = [expr];\n\n            while (startIndex < length) {\n                if (!match(',')) {\n                    break;\n                }\n                lex();\n                expressions.push(isolateCoverGrammar(parseAssignmentExpression));\n            }\n\n            expr = new WrappingNode(startToken).finishSequenceExpression(expressions);\n        }\n\n        return expr;\n    }\n\n    // ECMA-262 13.2 Block\n\n    function parseStatementListItem() {\n        if (lookahead.type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'export':\n                if (state.sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalExportDeclaration);\n                }\n                return parseExportDeclaration();\n            case 'import':\n                if (state.sourceType !== 'module') {\n                    tolerateUnexpectedToken(lookahead, Messages.IllegalImportDeclaration);\n                }\n                return parseImportDeclaration();\n            case 'const':\n                return parseLexicalDeclaration({inFor: false});\n            case 'function':\n                return parseFunctionDeclaration(new Node());\n            case 'class':\n                return parseClassDeclaration();\n            }\n        }\n\n        if (matchKeyword('let') && isLexicalDeclaration()) {\n            return parseLexicalDeclaration({inFor: false});\n        }\n\n        return parseStatement();\n    }\n\n    function parseStatementList() {\n        var list = [];\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            list.push(parseStatementListItem());\n        }\n\n        return list;\n    }\n\n    function parseBlock() {\n        var block, node = new Node();\n\n        expect('{');\n\n        block = parseStatementList();\n\n        expect('}');\n\n        return node.finishBlockStatement(block);\n    }\n\n    // ECMA-262 13.3.2 Variable Statement\n\n    function parseVariableIdentifier(kind) {\n        var token, node = new Node();\n\n        token = lex();\n\n        if (token.type === Token.Keyword && token.value === 'yield') {\n            if (strict) {\n                tolerateUnexpectedToken(token, Messages.StrictReservedWord);\n            } if (!state.allowYield) {\n                throwUnexpectedToken(token);\n            }\n        } else if (token.type !== Token.Identifier) {\n            if (strict && token.type === Token.Keyword && isStrictModeReservedWord(token.value)) {\n                tolerateUnexpectedToken(token, Messages.StrictReservedWord);\n            } else {\n                if (strict || token.value !== 'let' || kind !== 'var') {\n                    throwUnexpectedToken(token);\n                }\n            }\n        } else if (state.sourceType === 'module' && token.type === Token.Identifier && token.value === 'await') {\n            tolerateUnexpectedToken(token);\n        }\n\n        return node.finishIdentifier(token.value);\n    }\n\n    function parseVariableDeclaration(options) {\n        var init = null, id, node = new Node(), params = [];\n\n        id = parsePattern(params, 'var');\n\n        // ECMA-262 12.2.1\n        if (strict && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (match('=')) {\n            lex();\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        } else if (id.type !== Syntax.Identifier && !options.inFor) {\n            expect('=');\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseVariableDeclarationList(options) {\n        var opt, list;\n\n        opt = { inFor: options.inFor };\n        list = [parseVariableDeclaration(opt)];\n\n        while (match(',')) {\n            lex();\n            list.push(parseVariableDeclaration(opt));\n        }\n\n        return list;\n    }\n\n    function parseVariableStatement(node) {\n        var declarations;\n\n        expectKeyword('var');\n\n        declarations = parseVariableDeclarationList({ inFor: false });\n\n        consumeSemicolon();\n\n        return node.finishVariableDeclaration(declarations);\n    }\n\n    // ECMA-262 13.3.1 Let and Const Declarations\n\n    function parseLexicalBinding(kind, options) {\n        var init = null, id, node = new Node(), params = [];\n\n        id = parsePattern(params, kind);\n\n        // ECMA-262 12.2.1\n        if (strict && id.type === Syntax.Identifier && isRestrictedWord(id.name)) {\n            tolerateError(Messages.StrictVarName);\n        }\n\n        if (kind === 'const') {\n            if (!matchKeyword('in') && !matchContextualKeyword('of')) {\n                expect('=');\n                init = isolateCoverGrammar(parseAssignmentExpression);\n            }\n        } else if ((!options.inFor && id.type !== Syntax.Identifier) || match('=')) {\n            expect('=');\n            init = isolateCoverGrammar(parseAssignmentExpression);\n        }\n\n        return node.finishVariableDeclarator(id, init);\n    }\n\n    function parseBindingList(kind, options) {\n        var list = [parseLexicalBinding(kind, options)];\n\n        while (match(',')) {\n            lex();\n            list.push(parseLexicalBinding(kind, options));\n        }\n\n        return list;\n    }\n\n\n    function tokenizerState() {\n        return {\n            index: index,\n            lineNumber: lineNumber,\n            lineStart: lineStart,\n            hasLineTerminator: hasLineTerminator,\n            lastIndex: lastIndex,\n            lastLineNumber: lastLineNumber,\n            lastLineStart: lastLineStart,\n            startIndex: startIndex,\n            startLineNumber: startLineNumber,\n            startLineStart: startLineStart,\n            lookahead: lookahead,\n            tokenCount: extra.tokens ? extra.tokens.length : 0\n        };\n    }\n\n    function resetTokenizerState(ts) {\n        index = ts.index;\n        lineNumber = ts.lineNumber;\n        lineStart = ts.lineStart;\n        hasLineTerminator = ts.hasLineTerminator;\n        lastIndex = ts.lastIndex;\n        lastLineNumber = ts.lastLineNumber;\n        lastLineStart = ts.lastLineStart;\n        startIndex = ts.startIndex;\n        startLineNumber = ts.startLineNumber;\n        startLineStart = ts.startLineStart;\n        lookahead = ts.lookahead;\n        if (extra.tokens) {\n            extra.tokens.splice(ts.tokenCount, extra.tokens.length);\n        }\n    }\n\n    function isLexicalDeclaration() {\n        var lexical, ts;\n\n        ts = tokenizerState();\n\n        lex();\n        lexical = (lookahead.type === Token.Identifier) || match('[') || match('{') ||\n            matchKeyword('let') || matchKeyword('yield');\n\n        resetTokenizerState(ts);\n\n        return lexical;\n    }\n\n    function parseLexicalDeclaration(options) {\n        var kind, declarations, node = new Node();\n\n        kind = lex().value;\n        assert(kind === 'let' || kind === 'const', 'Lexical declaration must be either let or const');\n\n        declarations = parseBindingList(kind, options);\n\n        consumeSemicolon();\n\n        return node.finishLexicalDeclaration(declarations, kind);\n    }\n\n    function parseRestElement(params) {\n        var param, node = new Node();\n\n        lex();\n\n        if (match('{')) {\n            throwError(Messages.ObjectPatternAsRestParameter);\n        }\n\n        params.push(lookahead);\n\n        param = parseVariableIdentifier();\n\n        if (match('=')) {\n            throwError(Messages.DefaultRestParameter);\n        }\n\n        if (!match(')')) {\n            throwError(Messages.ParameterAfterRestParameter);\n        }\n\n        return node.finishRestElement(param);\n    }\n\n    // ECMA-262 13.4 Empty Statement\n\n    function parseEmptyStatement(node) {\n        expect(';');\n        return node.finishEmptyStatement();\n    }\n\n    // ECMA-262 12.4 Expression Statement\n\n    function parseExpressionStatement(node) {\n        var expr = parseExpression();\n        consumeSemicolon();\n        return node.finishExpressionStatement(expr);\n    }\n\n    // ECMA-262 13.6 If statement\n\n    function parseIfStatement(node) {\n        var test, consequent, alternate;\n\n        expectKeyword('if');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        consequent = parseStatement();\n\n        if (matchKeyword('else')) {\n            lex();\n            alternate = parseStatement();\n        } else {\n            alternate = null;\n        }\n\n        return node.finishIfStatement(test, consequent, alternate);\n    }\n\n    // ECMA-262 13.7 Iteration Statements\n\n    function parseDoWhileStatement(node) {\n        var body, test, oldInIteration;\n\n        expectKeyword('do');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        if (match(';')) {\n            lex();\n        }\n\n        return node.finishDoWhileStatement(body, test);\n    }\n\n    function parseWhileStatement(node) {\n        var test, body, oldInIteration;\n\n        expectKeyword('while');\n\n        expect('(');\n\n        test = parseExpression();\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = parseStatement();\n\n        state.inIteration = oldInIteration;\n\n        return node.finishWhileStatement(test, body);\n    }\n\n    function parseForStatement(node) {\n        var init, forIn, initSeq, initStartToken, test, update, left, right, kind, declarations,\n            body, oldInIteration, previousAllowIn = state.allowIn;\n\n        init = test = update = null;\n        forIn = true;\n\n        expectKeyword('for');\n\n        expect('(');\n\n        if (match(';')) {\n            lex();\n        } else {\n            if (matchKeyword('var')) {\n                init = new Node();\n                lex();\n\n                state.allowIn = false;\n                declarations = parseVariableDeclarationList({ inFor: true });\n                state.allowIn = previousAllowIn;\n\n                if (declarations.length === 1 && matchKeyword('in')) {\n                    init = init.finishVariableDeclaration(declarations);\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else if (declarations.length === 1 && declarations[0].init === null && matchContextualKeyword('of')) {\n                    init = init.finishVariableDeclaration(declarations);\n                    lex();\n                    left = init;\n                    right = parseAssignmentExpression();\n                    init = null;\n                    forIn = false;\n                } else {\n                    init = init.finishVariableDeclaration(declarations);\n                    expect(';');\n                }\n            } else if (matchKeyword('const') || matchKeyword('let')) {\n                init = new Node();\n                kind = lex().value;\n\n                if (!strict && lookahead.value === 'in') {\n                    init = init.finishIdentifier(kind);\n                    lex();\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else {\n                    state.allowIn = false;\n                    declarations = parseBindingList(kind, {inFor: true});\n                    state.allowIn = previousAllowIn;\n\n                    if (declarations.length === 1 && declarations[0].init === null && matchKeyword('in')) {\n                        init = init.finishLexicalDeclaration(declarations, kind);\n                        lex();\n                        left = init;\n                        right = parseExpression();\n                        init = null;\n                    } else if (declarations.length === 1 && declarations[0].init === null && matchContextualKeyword('of')) {\n                        init = init.finishLexicalDeclaration(declarations, kind);\n                        lex();\n                        left = init;\n                        right = parseAssignmentExpression();\n                        init = null;\n                        forIn = false;\n                    } else {\n                        consumeSemicolon();\n                        init = init.finishLexicalDeclaration(declarations, kind);\n                    }\n                }\n            } else {\n                initStartToken = lookahead;\n                state.allowIn = false;\n                init = inheritCoverGrammar(parseAssignmentExpression);\n                state.allowIn = previousAllowIn;\n\n                if (matchKeyword('in')) {\n                    if (!isAssignmentTarget) {\n                        tolerateError(Messages.InvalidLHSInForIn);\n                    }\n\n                    lex();\n                    reinterpretExpressionAsPattern(init);\n                    left = init;\n                    right = parseExpression();\n                    init = null;\n                } else if (matchContextualKeyword('of')) {\n                    if (!isAssignmentTarget) {\n                        tolerateError(Messages.InvalidLHSInForLoop);\n                    }\n\n                    lex();\n                    reinterpretExpressionAsPattern(init);\n                    left = init;\n                    right = parseAssignmentExpression();\n                    init = null;\n                    forIn = false;\n                } else {\n                    if (match(',')) {\n                        initSeq = [init];\n                        while (match(',')) {\n                            lex();\n                            initSeq.push(isolateCoverGrammar(parseAssignmentExpression));\n                        }\n                        init = new WrappingNode(initStartToken).finishSequenceExpression(initSeq);\n                    }\n                    expect(';');\n                }\n            }\n        }\n\n        if (typeof left === 'undefined') {\n\n            if (!match(';')) {\n                test = parseExpression();\n            }\n            expect(';');\n\n            if (!match(')')) {\n                update = parseExpression();\n            }\n        }\n\n        expect(')');\n\n        oldInIteration = state.inIteration;\n        state.inIteration = true;\n\n        body = isolateCoverGrammar(parseStatement);\n\n        state.inIteration = oldInIteration;\n\n        return (typeof left === 'undefined') ?\n                node.finishForStatement(init, test, update, body) :\n                forIn ? node.finishForInStatement(left, right, body) :\n                    node.finishForOfStatement(left, right, body);\n    }\n\n    // ECMA-262 13.8 The continue statement\n\n    function parseContinueStatement(node) {\n        var label = null, key;\n\n        expectKeyword('continue');\n\n        // Optimize the most common form: 'continue;'.\n        if (source.charCodeAt(startIndex) === 0x3B) {\n            lex();\n\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!state.inIteration) {\n                throwError(Messages.IllegalContinue);\n            }\n\n            return node.finishContinueStatement(null);\n        }\n\n        if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !state.inIteration) {\n            throwError(Messages.IllegalContinue);\n        }\n\n        return node.finishContinueStatement(label);\n    }\n\n    // ECMA-262 13.9 The break statement\n\n    function parseBreakStatement(node) {\n        var label = null, key;\n\n        expectKeyword('break');\n\n        // Catch the very common case first: immediately a semicolon (U+003B).\n        if (source.charCodeAt(lastIndex) === 0x3B) {\n            lex();\n\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n\n            return node.finishBreakStatement(null);\n        }\n\n        if (hasLineTerminator) {\n            if (!(state.inIteration || state.inSwitch)) {\n                throwError(Messages.IllegalBreak);\n            }\n        } else if (lookahead.type === Token.Identifier) {\n            label = parseVariableIdentifier();\n\n            key = '$' + label.name;\n            if (!Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.UnknownLabel, label.name);\n            }\n        }\n\n        consumeSemicolon();\n\n        if (label === null && !(state.inIteration || state.inSwitch)) {\n            throwError(Messages.IllegalBreak);\n        }\n\n        return node.finishBreakStatement(label);\n    }\n\n    // ECMA-262 13.10 The return statement\n\n    function parseReturnStatement(node) {\n        var argument = null;\n\n        expectKeyword('return');\n\n        if (!state.inFunctionBody) {\n            tolerateError(Messages.IllegalReturn);\n        }\n\n        // 'return' followed by a space and an identifier is very common.\n        if (source.charCodeAt(lastIndex) === 0x20) {\n            if (isIdentifierStart(source.charCodeAt(lastIndex + 1))) {\n                argument = parseExpression();\n                consumeSemicolon();\n                return node.finishReturnStatement(argument);\n            }\n        }\n\n        if (hasLineTerminator) {\n            // HACK\n            return node.finishReturnStatement(null);\n        }\n\n        if (!match(';')) {\n            if (!match('}') && lookahead.type !== Token.EOF) {\n                argument = parseExpression();\n            }\n        }\n\n        consumeSemicolon();\n\n        return node.finishReturnStatement(argument);\n    }\n\n    // ECMA-262 13.11 The with statement\n\n    function parseWithStatement(node) {\n        var object, body;\n\n        if (strict) {\n            tolerateError(Messages.StrictModeWith);\n        }\n\n        expectKeyword('with');\n\n        expect('(');\n\n        object = parseExpression();\n\n        expect(')');\n\n        body = parseStatement();\n\n        return node.finishWithStatement(object, body);\n    }\n\n    // ECMA-262 13.12 The switch statement\n\n    function parseSwitchCase() {\n        var test, consequent = [], statement, node = new Node();\n\n        if (matchKeyword('default')) {\n            lex();\n            test = null;\n        } else {\n            expectKeyword('case');\n            test = parseExpression();\n        }\n        expect(':');\n\n        while (startIndex < length) {\n            if (match('}') || matchKeyword('default') || matchKeyword('case')) {\n                break;\n            }\n            statement = parseStatementListItem();\n            consequent.push(statement);\n        }\n\n        return node.finishSwitchCase(test, consequent);\n    }\n\n    function parseSwitchStatement(node) {\n        var discriminant, cases, clause, oldInSwitch, defaultFound;\n\n        expectKeyword('switch');\n\n        expect('(');\n\n        discriminant = parseExpression();\n\n        expect(')');\n\n        expect('{');\n\n        cases = [];\n\n        if (match('}')) {\n            lex();\n            return node.finishSwitchStatement(discriminant, cases);\n        }\n\n        oldInSwitch = state.inSwitch;\n        state.inSwitch = true;\n        defaultFound = false;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            clause = parseSwitchCase();\n            if (clause.test === null) {\n                if (defaultFound) {\n                    throwError(Messages.MultipleDefaultsInSwitch);\n                }\n                defaultFound = true;\n            }\n            cases.push(clause);\n        }\n\n        state.inSwitch = oldInSwitch;\n\n        expect('}');\n\n        return node.finishSwitchStatement(discriminant, cases);\n    }\n\n    // ECMA-262 13.14 The throw statement\n\n    function parseThrowStatement(node) {\n        var argument;\n\n        expectKeyword('throw');\n\n        if (hasLineTerminator) {\n            throwError(Messages.NewlineAfterThrow);\n        }\n\n        argument = parseExpression();\n\n        consumeSemicolon();\n\n        return node.finishThrowStatement(argument);\n    }\n\n    // ECMA-262 13.15 The try statement\n\n    function parseCatchClause() {\n        var param, params = [], paramMap = {}, key, i, body, node = new Node();\n\n        expectKeyword('catch');\n\n        expect('(');\n        if (match(')')) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        param = parsePattern(params);\n        for (i = 0; i < params.length; i++) {\n            key = '$' + params[i].value;\n            if (Object.prototype.hasOwnProperty.call(paramMap, key)) {\n                tolerateError(Messages.DuplicateBinding, params[i].value);\n            }\n            paramMap[key] = true;\n        }\n\n        // ECMA-262 12.14.1\n        if (strict && isRestrictedWord(param.name)) {\n            tolerateError(Messages.StrictCatchVariable);\n        }\n\n        expect(')');\n        body = parseBlock();\n        return node.finishCatchClause(param, body);\n    }\n\n    function parseTryStatement(node) {\n        var block, handler = null, finalizer = null;\n\n        expectKeyword('try');\n\n        block = parseBlock();\n\n        if (matchKeyword('catch')) {\n            handler = parseCatchClause();\n        }\n\n        if (matchKeyword('finally')) {\n            lex();\n            finalizer = parseBlock();\n        }\n\n        if (!handler && !finalizer) {\n            throwError(Messages.NoCatchOrFinally);\n        }\n\n        return node.finishTryStatement(block, handler, finalizer);\n    }\n\n    // ECMA-262 13.16 The debugger statement\n\n    function parseDebuggerStatement(node) {\n        expectKeyword('debugger');\n\n        consumeSemicolon();\n\n        return node.finishDebuggerStatement();\n    }\n\n    // 13 Statements\n\n    function parseStatement() {\n        var type = lookahead.type,\n            expr,\n            labeledBody,\n            key,\n            node;\n\n        if (type === Token.EOF) {\n            throwUnexpectedToken(lookahead);\n        }\n\n        if (type === Token.Punctuator && lookahead.value === '{') {\n            return parseBlock();\n        }\n        isAssignmentTarget = isBindingElement = true;\n        node = new Node();\n\n        if (type === Token.Punctuator) {\n            switch (lookahead.value) {\n            case ';':\n                return parseEmptyStatement(node);\n            case '(':\n                return parseExpressionStatement(node);\n            default:\n                break;\n            }\n        } else if (type === Token.Keyword) {\n            switch (lookahead.value) {\n            case 'break':\n                return parseBreakStatement(node);\n            case 'continue':\n                return parseContinueStatement(node);\n            case 'debugger':\n                return parseDebuggerStatement(node);\n            case 'do':\n                return parseDoWhileStatement(node);\n            case 'for':\n                return parseForStatement(node);\n            case 'function':\n                return parseFunctionDeclaration(node);\n            case 'if':\n                return parseIfStatement(node);\n            case 'return':\n                return parseReturnStatement(node);\n            case 'switch':\n                return parseSwitchStatement(node);\n            case 'throw':\n                return parseThrowStatement(node);\n            case 'try':\n                return parseTryStatement(node);\n            case 'var':\n                return parseVariableStatement(node);\n            case 'while':\n                return parseWhileStatement(node);\n            case 'with':\n                return parseWithStatement(node);\n            default:\n                break;\n            }\n        }\n\n        expr = parseExpression();\n\n        // ECMA-262 12.12 Labelled Statements\n        if ((expr.type === Syntax.Identifier) && match(':')) {\n            lex();\n\n            key = '$' + expr.name;\n            if (Object.prototype.hasOwnProperty.call(state.labelSet, key)) {\n                throwError(Messages.Redeclaration, 'Label', expr.name);\n            }\n\n            state.labelSet[key] = true;\n            labeledBody = parseStatement();\n            delete state.labelSet[key];\n            return node.finishLabeledStatement(expr, labeledBody);\n        }\n\n        consumeSemicolon();\n\n        return node.finishExpressionStatement(expr);\n    }\n\n    // ECMA-262 14.1 Function Definition\n\n    function parseFunctionSourceElements() {\n        var statement, body = [], token, directive, firstRestricted,\n            oldLabelSet, oldInIteration, oldInSwitch, oldInFunctionBody, oldParenthesisCount,\n            node = new Node();\n\n        expect('{');\n\n        while (startIndex < length) {\n            if (lookahead.type !== Token.StringLiteral) {\n                break;\n            }\n            token = lookahead;\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        oldLabelSet = state.labelSet;\n        oldInIteration = state.inIteration;\n        oldInSwitch = state.inSwitch;\n        oldInFunctionBody = state.inFunctionBody;\n        oldParenthesisCount = state.parenthesizedCount;\n\n        state.labelSet = {};\n        state.inIteration = false;\n        state.inSwitch = false;\n        state.inFunctionBody = true;\n        state.parenthesizedCount = 0;\n\n        while (startIndex < length) {\n            if (match('}')) {\n                break;\n            }\n            body.push(parseStatementListItem());\n        }\n\n        expect('}');\n\n        state.labelSet = oldLabelSet;\n        state.inIteration = oldInIteration;\n        state.inSwitch = oldInSwitch;\n        state.inFunctionBody = oldInFunctionBody;\n        state.parenthesizedCount = oldParenthesisCount;\n\n        return node.finishBlockStatement(body);\n    }\n\n    function validateParam(options, param, name) {\n        var key = '$' + name;\n        if (strict) {\n            if (isRestrictedWord(name)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamName;\n            }\n            if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        } else if (!options.firstRestricted) {\n            if (isRestrictedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictParamName;\n            } else if (isStrictModeReservedWord(name)) {\n                options.firstRestricted = param;\n                options.message = Messages.StrictReservedWord;\n            } else if (Object.prototype.hasOwnProperty.call(options.paramSet, key)) {\n                options.stricted = param;\n                options.message = Messages.StrictParamDupe;\n            }\n        }\n        options.paramSet[key] = true;\n    }\n\n    function parseParam(options) {\n        var token, param, params = [], i, def;\n\n        token = lookahead;\n        if (token.value === '...') {\n            param = parseRestElement(params);\n            validateParam(options, param.argument, param.argument.name);\n            options.params.push(param);\n            options.defaults.push(null);\n            return false;\n        }\n\n        param = parsePatternWithDefault(params);\n        for (i = 0; i < params.length; i++) {\n            validateParam(options, params[i], params[i].value);\n        }\n\n        if (param.type === Syntax.AssignmentPattern) {\n            def = param.right;\n            param = param.left;\n            ++options.defaultCount;\n        }\n\n        options.params.push(param);\n        options.defaults.push(def);\n\n        return !match(')');\n    }\n\n    function parseParams(firstRestricted) {\n        var options;\n\n        options = {\n            params: [],\n            defaultCount: 0,\n            defaults: [],\n            firstRestricted: firstRestricted\n        };\n\n        expect('(');\n\n        if (!match(')')) {\n            options.paramSet = {};\n            while (startIndex < length) {\n                if (!parseParam(options)) {\n                    break;\n                }\n                expect(',');\n            }\n        }\n\n        expect(')');\n\n        if (options.defaultCount === 0) {\n            options.defaults = [];\n        }\n\n        return {\n            params: options.params,\n            defaults: options.defaults,\n            stricted: options.stricted,\n            firstRestricted: options.firstRestricted,\n            message: options.message\n        };\n    }\n\n    function parseFunctionDeclaration(node, identifierIsOptional) {\n        var id = null, params = [], defaults = [], body, token, stricted, tmp, firstRestricted, message, previousStrict,\n            isGenerator, previousAllowYield;\n\n        previousAllowYield = state.allowYield;\n\n        expectKeyword('function');\n\n        isGenerator = match('*');\n        if (isGenerator) {\n            lex();\n        }\n\n        if (!identifierIsOptional || !match('(')) {\n            token = lookahead;\n            id = parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        state.allowYield = !isGenerator;\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n\n        strict = previousStrict;\n        state.allowYield = previousAllowYield;\n\n        return node.finishFunctionDeclaration(id, params, defaults, body, isGenerator);\n    }\n\n    function parseFunctionExpression() {\n        var token, id = null, stricted, firstRestricted, message, tmp,\n            params = [], defaults = [], body, previousStrict, node = new Node(),\n            isGenerator, previousAllowYield;\n\n        previousAllowYield = state.allowYield;\n\n        expectKeyword('function');\n\n        isGenerator = match('*');\n        if (isGenerator) {\n            lex();\n        }\n\n        state.allowYield = !isGenerator;\n        if (!match('(')) {\n            token = lookahead;\n            id = (!strict && !isGenerator && matchKeyword('yield')) ? parseNonComputedProperty() : parseVariableIdentifier();\n            if (strict) {\n                if (isRestrictedWord(token.value)) {\n                    tolerateUnexpectedToken(token, Messages.StrictFunctionName);\n                }\n            } else {\n                if (isRestrictedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictFunctionName;\n                } else if (isStrictModeReservedWord(token.value)) {\n                    firstRestricted = token;\n                    message = Messages.StrictReservedWord;\n                }\n            }\n        }\n\n        tmp = parseParams(firstRestricted);\n        params = tmp.params;\n        defaults = tmp.defaults;\n        stricted = tmp.stricted;\n        firstRestricted = tmp.firstRestricted;\n        if (tmp.message) {\n            message = tmp.message;\n        }\n\n        previousStrict = strict;\n        body = parseFunctionSourceElements();\n        if (strict && firstRestricted) {\n            throwUnexpectedToken(firstRestricted, message);\n        }\n        if (strict && stricted) {\n            tolerateUnexpectedToken(stricted, message);\n        }\n        strict = previousStrict;\n        state.allowYield = previousAllowYield;\n\n        return node.finishFunctionExpression(id, params, defaults, body, isGenerator);\n    }\n\n    // ECMA-262 14.5 Class Definitions\n\n    function parseClassBody() {\n        var classBody, token, isStatic, hasConstructor = false, body, method, computed, key;\n\n        classBody = new Node();\n\n        expect('{');\n        body = [];\n        while (!match('}')) {\n            if (match(';')) {\n                lex();\n            } else {\n                method = new Node();\n                token = lookahead;\n                isStatic = false;\n                computed = match('[');\n                if (match('*')) {\n                    lex();\n                } else {\n                    key = parseObjectPropertyKey();\n                    if (key.name === 'static' && (lookaheadPropertyName() || match('*'))) {\n                        token = lookahead;\n                        isStatic = true;\n                        computed = match('[');\n                        if (match('*')) {\n                            lex();\n                        } else {\n                            key = parseObjectPropertyKey();\n                        }\n                    }\n                }\n                method = tryParseMethodDefinition(token, key, computed, method);\n                if (method) {\n                    method['static'] = isStatic; // jscs:ignore requireDotNotation\n                    if (method.kind === 'init') {\n                        method.kind = 'method';\n                    }\n                    if (!isStatic) {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'constructor') {\n                            if (method.kind !== 'method' || !method.method || method.value.generator) {\n                                throwUnexpectedToken(token, Messages.ConstructorSpecialMethod);\n                            }\n                            if (hasConstructor) {\n                                throwUnexpectedToken(token, Messages.DuplicateConstructor);\n                            } else {\n                                hasConstructor = true;\n                            }\n                            method.kind = 'constructor';\n                        }\n                    } else {\n                        if (!method.computed && (method.key.name || method.key.value.toString()) === 'prototype') {\n                            throwUnexpectedToken(token, Messages.StaticPrototype);\n                        }\n                    }\n                    method.type = Syntax.MethodDefinition;\n                    delete method.method;\n                    delete method.shorthand;\n                    body.push(method);\n                } else {\n                    throwUnexpectedToken(lookahead);\n                }\n            }\n        }\n        lex();\n        return classBody.finishClassBody(body);\n    }\n\n    function parseClassDeclaration(identifierIsOptional) {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (!identifierIsOptional || lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassDeclaration(id, superClass, classBody);\n    }\n\n    function parseClassExpression() {\n        var id = null, superClass = null, classNode = new Node(), classBody, previousStrict = strict;\n        strict = true;\n\n        expectKeyword('class');\n\n        if (lookahead.type === Token.Identifier) {\n            id = parseVariableIdentifier();\n        }\n\n        if (matchKeyword('extends')) {\n            lex();\n            superClass = isolateCoverGrammar(parseLeftHandSideExpressionAllowCall);\n        }\n        classBody = parseClassBody();\n        strict = previousStrict;\n\n        return classNode.finishClassExpression(id, superClass, classBody);\n    }\n\n    // ECMA-262 15.2 Modules\n\n    function parseModuleSpecifier() {\n        var node = new Node();\n\n        if (lookahead.type !== Token.StringLiteral) {\n            throwError(Messages.InvalidModuleSpecifier);\n        }\n        return node.finishLiteral(lex());\n    }\n\n    // ECMA-262 15.2.3 Exports\n\n    function parseExportSpecifier() {\n        var exported, local, node = new Node(), def;\n        if (matchKeyword('default')) {\n            // export {default} from 'something';\n            def = new Node();\n            lex();\n            local = def.finishIdentifier('default');\n        } else {\n            local = parseVariableIdentifier();\n        }\n        if (matchContextualKeyword('as')) {\n            lex();\n            exported = parseNonComputedProperty();\n        }\n        return node.finishExportSpecifier(local, exported);\n    }\n\n    function parseExportNamedDeclaration(node) {\n        var declaration = null,\n            isExportFromIdentifier,\n            src = null, specifiers = [];\n\n        // non-default export\n        if (lookahead.type === Token.Keyword) {\n            // covers:\n            // export var f = 1;\n            switch (lookahead.value) {\n                case 'let':\n                case 'const':\n                    declaration = parseLexicalDeclaration({inFor: false});\n                    return node.finishExportNamedDeclaration(declaration, specifiers, null);\n                case 'var':\n                case 'class':\n                case 'function':\n                    declaration = parseStatementListItem();\n                    return node.finishExportNamedDeclaration(declaration, specifiers, null);\n            }\n        }\n\n        expect('{');\n        while (!match('}')) {\n            isExportFromIdentifier = isExportFromIdentifier || matchKeyword('default');\n            specifiers.push(parseExportSpecifier());\n            if (!match('}')) {\n                expect(',');\n                if (match('}')) {\n                    break;\n                }\n            }\n        }\n        expect('}');\n\n        if (matchContextualKeyword('from')) {\n            // covering:\n            // export {default} from 'foo';\n            // export {foo} from 'foo';\n            lex();\n            src = parseModuleSpecifier();\n            consumeSemicolon();\n        } else if (isExportFromIdentifier) {\n            // covering:\n            // export {default}; // missing fromClause\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        } else {\n            // cover\n            // export {foo};\n            consumeSemicolon();\n        }\n        return node.finishExportNamedDeclaration(declaration, specifiers, src);\n    }\n\n    function parseExportDefaultDeclaration(node) {\n        var declaration = null,\n            expression = null;\n\n        // covers:\n        // export default ...\n        expectKeyword('default');\n\n        if (matchKeyword('function')) {\n            // covers:\n            // export default function foo () {}\n            // export default function () {}\n            declaration = parseFunctionDeclaration(new Node(), true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n        if (matchKeyword('class')) {\n            declaration = parseClassDeclaration(true);\n            return node.finishExportDefaultDeclaration(declaration);\n        }\n\n        if (matchContextualKeyword('from')) {\n            throwError(Messages.UnexpectedToken, lookahead.value);\n        }\n\n        // covers:\n        // export default {};\n        // export default [];\n        // export default (1 + 2);\n        if (match('{')) {\n            expression = parseObjectInitializer();\n        } else if (match('[')) {\n            expression = parseArrayInitializer();\n        } else {\n            expression = parseAssignmentExpression();\n        }\n        consumeSemicolon();\n        return node.finishExportDefaultDeclaration(expression);\n    }\n\n    function parseExportAllDeclaration(node) {\n        var src;\n\n        // covers:\n        // export * from 'foo';\n        expect('*');\n        if (!matchContextualKeyword('from')) {\n            throwError(lookahead.value ?\n                    Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n        }\n        lex();\n        src = parseModuleSpecifier();\n        consumeSemicolon();\n\n        return node.finishExportAllDeclaration(src);\n    }\n\n    function parseExportDeclaration() {\n        var node = new Node();\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalExportDeclaration);\n        }\n\n        expectKeyword('export');\n\n        if (matchKeyword('default')) {\n            return parseExportDefaultDeclaration(node);\n        }\n        if (match('*')) {\n            return parseExportAllDeclaration(node);\n        }\n        return parseExportNamedDeclaration(node);\n    }\n\n    // ECMA-262 15.2.2 Imports\n\n    function parseImportSpecifier() {\n        // import {<foo as bar>} ...;\n        var local, imported, node = new Node();\n\n        imported = parseNonComputedProperty();\n        if (matchContextualKeyword('as')) {\n            lex();\n            local = parseVariableIdentifier();\n        }\n\n        return node.finishImportSpecifier(local, imported);\n    }\n\n    function parseNamedImports() {\n        var specifiers = [];\n        // {foo, bar as bas}\n        expect('{');\n        while (!match('}')) {\n            specifiers.push(parseImportSpecifier());\n            if (!match('}')) {\n                expect(',');\n                if (match('}')) {\n                    break;\n                }\n            }\n        }\n        expect('}');\n        return specifiers;\n    }\n\n    function parseImportDefaultSpecifier() {\n        // import <foo> ...;\n        var local, node = new Node();\n\n        local = parseNonComputedProperty();\n\n        return node.finishImportDefaultSpecifier(local);\n    }\n\n    function parseImportNamespaceSpecifier() {\n        // import <* as foo> ...;\n        var local, node = new Node();\n\n        expect('*');\n        if (!matchContextualKeyword('as')) {\n            throwError(Messages.NoAsAfterImportNamespace);\n        }\n        lex();\n        local = parseNonComputedProperty();\n\n        return node.finishImportNamespaceSpecifier(local);\n    }\n\n    function parseImportDeclaration() {\n        var specifiers = [], src, node = new Node();\n\n        if (state.inFunctionBody) {\n            throwError(Messages.IllegalImportDeclaration);\n        }\n\n        expectKeyword('import');\n\n        if (lookahead.type === Token.StringLiteral) {\n            // import 'foo';\n            src = parseModuleSpecifier();\n        } else {\n\n            if (match('{')) {\n                // import {bar}\n                specifiers = specifiers.concat(parseNamedImports());\n            } else if (match('*')) {\n                // import * as foo\n                specifiers.push(parseImportNamespaceSpecifier());\n            } else if (isIdentifierName(lookahead) && !matchKeyword('default')) {\n                // import foo\n                specifiers.push(parseImportDefaultSpecifier());\n                if (match(',')) {\n                    lex();\n                    if (match('*')) {\n                        // import foo, * as foo\n                        specifiers.push(parseImportNamespaceSpecifier());\n                    } else if (match('{')) {\n                        // import foo, {bar}\n                        specifiers = specifiers.concat(parseNamedImports());\n                    } else {\n                        throwUnexpectedToken(lookahead);\n                    }\n                }\n            } else {\n                throwUnexpectedToken(lex());\n            }\n\n            if (!matchContextualKeyword('from')) {\n                throwError(lookahead.value ?\n                        Messages.UnexpectedToken : Messages.MissingFromClause, lookahead.value);\n            }\n            lex();\n            src = parseModuleSpecifier();\n        }\n\n        consumeSemicolon();\n        return node.finishImportDeclaration(specifiers, src);\n    }\n\n    // ECMA-262 15.1 Scripts\n\n    function parseScriptBody() {\n        var statement, body = [], token, directive, firstRestricted;\n\n        while (startIndex < length) {\n            token = lookahead;\n            if (token.type !== Token.StringLiteral) {\n                break;\n            }\n\n            statement = parseStatementListItem();\n            body.push(statement);\n            if (statement.expression.type !== Syntax.Literal) {\n                // this is not directive\n                break;\n            }\n            directive = source.slice(token.start + 1, token.end - 1);\n            if (directive === 'use strict') {\n                strict = true;\n                if (firstRestricted) {\n                    tolerateUnexpectedToken(firstRestricted, Messages.StrictOctalLiteral);\n                }\n            } else {\n                if (!firstRestricted && token.octal) {\n                    firstRestricted = token;\n                }\n            }\n        }\n\n        while (startIndex < length) {\n            statement = parseStatementListItem();\n            /* istanbul ignore if */\n            if (typeof statement === 'undefined') {\n                break;\n            }\n            body.push(statement);\n        }\n        return body;\n    }\n\n    function parseProgram() {\n        var body, node;\n\n        peek();\n        node = new Node();\n\n        body = parseScriptBody();\n        return node.finishProgram(body, state.sourceType);\n    }\n\n    function filterTokenLocation() {\n        var i, entry, token, tokens = [];\n\n        for (i = 0; i < extra.tokens.length; ++i) {\n            entry = extra.tokens[i];\n            token = {\n                type: entry.type,\n                value: entry.value\n            };\n            if (entry.regex) {\n                token.regex = {\n                    pattern: entry.regex.pattern,\n                    flags: entry.regex.flags\n                };\n            }\n            if (extra.range) {\n                token.range = entry.range;\n            }\n            if (extra.loc) {\n                token.loc = entry.loc;\n            }\n            tokens.push(token);\n        }\n\n        extra.tokens = tokens;\n    }\n\n    function tokenize(code, options, delegate) {\n        var toString,\n            tokens;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            allowYield: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: []\n        };\n\n        extra = {};\n\n        // Options matching.\n        options = options || {};\n\n        // Of course we collect tokens here.\n        options.tokens = true;\n        extra.tokens = [];\n        extra.tokenValues = [];\n        extra.tokenize = true;\n        extra.delegate = delegate;\n\n        // The following two fields are necessary to compute the Regex tokens.\n        extra.openParenToken = -1;\n        extra.openCurlyToken = -1;\n\n        extra.range = (typeof options.range === 'boolean') && options.range;\n        extra.loc = (typeof options.loc === 'boolean') && options.loc;\n\n        if (typeof options.comment === 'boolean' && options.comment) {\n            extra.comments = [];\n        }\n        if (typeof options.tolerant === 'boolean' && options.tolerant) {\n            extra.errors = [];\n        }\n\n        try {\n            peek();\n            if (lookahead.type === Token.EOF) {\n                return extra.tokens;\n            }\n\n            lex();\n            while (lookahead.type !== Token.EOF) {\n                try {\n                    lex();\n                } catch (lexError) {\n                    if (extra.errors) {\n                        recordError(lexError);\n                        // We have to break on the first error\n                        // to avoid infinite loops.\n                        break;\n                    } else {\n                        throw lexError;\n                    }\n                }\n            }\n\n            tokens = extra.tokens;\n            if (typeof extra.errors !== 'undefined') {\n                tokens.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n        return tokens;\n    }\n\n    function parse(code, options) {\n        var program, toString;\n\n        toString = String;\n        if (typeof code !== 'string' && !(code instanceof String)) {\n            code = toString(code);\n        }\n\n        source = code;\n        index = 0;\n        lineNumber = (source.length > 0) ? 1 : 0;\n        lineStart = 0;\n        startIndex = index;\n        startLineNumber = lineNumber;\n        startLineStart = lineStart;\n        length = source.length;\n        lookahead = null;\n        state = {\n            allowIn: true,\n            allowYield: true,\n            labelSet: {},\n            inFunctionBody: false,\n            inIteration: false,\n            inSwitch: false,\n            lastCommentStart: -1,\n            curlyStack: [],\n            sourceType: 'script'\n        };\n        strict = false;\n\n        extra = {};\n        if (typeof options !== 'undefined') {\n            extra.range = (typeof options.range === 'boolean') && options.range;\n            extra.loc = (typeof options.loc === 'boolean') && options.loc;\n            extra.attachComment = (typeof options.attachComment === 'boolean') && options.attachComment;\n\n            if (extra.loc && options.source !== null && options.source !== undefined) {\n                extra.source = toString(options.source);\n            }\n\n            if (typeof options.tokens === 'boolean' && options.tokens) {\n                extra.tokens = [];\n            }\n            if (typeof options.comment === 'boolean' && options.comment) {\n                extra.comments = [];\n            }\n            if (typeof options.tolerant === 'boolean' && options.tolerant) {\n                extra.errors = [];\n            }\n            if (extra.attachComment) {\n                extra.range = true;\n                extra.comments = [];\n                extra.bottomRightStack = [];\n                extra.trailingComments = [];\n                extra.leadingComments = [];\n            }\n            if (options.sourceType === 'module') {\n                // very restrictive condition for now\n                state.sourceType = options.sourceType;\n                strict = true;\n            }\n        }\n\n        try {\n            program = parseProgram();\n            if (typeof extra.comments !== 'undefined') {\n                program.comments = extra.comments;\n            }\n            if (typeof extra.tokens !== 'undefined') {\n                filterTokenLocation();\n                program.tokens = extra.tokens;\n            }\n            if (typeof extra.errors !== 'undefined') {\n                program.errors = extra.errors;\n            }\n        } catch (e) {\n            throw e;\n        } finally {\n            extra = {};\n        }\n\n        return program;\n    }\n\n    // Sync with *.json manifests.\n    exports.version = '2.7.1';\n\n    exports.tokenize = tokenize;\n\n    exports.parse = parse;\n\n    // Deep copy.\n    /* istanbul ignore next */\n    exports.Syntax = (function () {\n        var name, types = {};\n\n        if (typeof Object.create === 'function') {\n            types = Object.create(null);\n        }\n\n        for (name in Syntax) {\n            if (Syntax.hasOwnProperty(name)) {\n                types[name] = Syntax[name];\n            }\n        }\n\n        if (typeof Object.freeze === 'function') {\n            Object.freeze(types);\n        }\n\n        return types;\n    }());\n\n}));\n/* vim: set sw=4 ts=4 et tw=80 : */\n","/*!\n * node-inherit\n * Copyright(c) 2011 Dmitry Filatov <dfilatov@yandex-team.ru>\n * MIT Licensed\n */\n\nmodule.exports = require('./lib/inherit');\n","/**\n * @module inherit\n * @version 2.2.2\n * @author Filatov Dmitry <dfilatov@yandex-team.ru>\n * @description This module provides some syntax sugar for \"class\" declarations, constructors, mixins, \"super\" calls and static members.\n */\n\n(function(global) {\n\nvar hasIntrospection = (function(){'_';}).toString().indexOf('_') > -1,\n    emptyBase = function() {},\n    hasOwnProperty = Object.prototype.hasOwnProperty,\n    objCreate = Object.create || function(ptp) {\n        var inheritance = function() {};\n        inheritance.prototype = ptp;\n        return new inheritance();\n    },\n    objKeys = Object.keys || function(obj) {\n        var res = [];\n        for(var i in obj) {\n            hasOwnProperty.call(obj, i) && res.push(i);\n        }\n        return res;\n    },\n    extend = function(o1, o2) {\n        for(var i in o2) {\n            hasOwnProperty.call(o2, i) && (o1[i] = o2[i]);\n        }\n\n        return o1;\n    },\n    toStr = Object.prototype.toString,\n    isArray = Array.isArray || function(obj) {\n        return toStr.call(obj) === '[object Array]';\n    },\n    isFunction = function(obj) {\n        return toStr.call(obj) === '[object Function]';\n    },\n    noOp = function() {},\n    needCheckProps = true,\n    testPropObj = { toString : '' };\n\nfor(var i in testPropObj) { // fucking ie hasn't toString, valueOf in for\n    testPropObj.hasOwnProperty(i) && (needCheckProps = false);\n}\n\nvar specProps = needCheckProps? ['toString', 'valueOf'] : null;\n\nfunction getPropList(obj) {\n    var res = objKeys(obj);\n    if(needCheckProps) {\n        var specProp, i = 0;\n        while(specProp = specProps[i++]) {\n            obj.hasOwnProperty(specProp) && res.push(specProp);\n        }\n    }\n\n    return res;\n}\n\nfunction override(base, res, add) {\n    var addList = getPropList(add),\n        j = 0, len = addList.length,\n        name, prop;\n    while(j < len) {\n        if((name = addList[j++]) === '__self') {\n            continue;\n        }\n        prop = add[name];\n        if(isFunction(prop) &&\n                (!hasIntrospection || prop.toString().indexOf('.__base') > -1)) {\n            res[name] = (function(name, prop) {\n                var baseMethod = base[name]?\n                        base[name] :\n                        name === '__constructor'? // case of inheritance from plane function\n                            res.__self.__parent :\n                            noOp;\n                return function() {\n                    var baseSaved = this.__base;\n                    this.__base = baseMethod;\n                    var res = prop.apply(this, arguments);\n                    this.__base = baseSaved;\n                    return res;\n                };\n            })(name, prop);\n        } else {\n            res[name] = prop;\n        }\n    }\n}\n\nfunction applyMixins(mixins, res) {\n    var i = 1, mixin;\n    while(mixin = mixins[i++]) {\n        res?\n            isFunction(mixin)?\n                inherit.self(res, mixin.prototype, mixin) :\n                inherit.self(res, mixin) :\n            res = isFunction(mixin)?\n                inherit(mixins[0], mixin.prototype, mixin) :\n                inherit(mixins[0], mixin);\n    }\n    return res || mixins[0];\n}\n\n/**\n* Creates class\n* @exports\n* @param {Function|Array} [baseClass|baseClassAndMixins] class (or class and mixins) to inherit from\n* @param {Object} prototypeFields\n* @param {Object} [staticFields]\n* @returns {Function} class\n*/\nfunction inherit() {\n    var args = arguments,\n        withMixins = isArray(args[0]),\n        hasBase = withMixins || isFunction(args[0]),\n        base = hasBase? withMixins? applyMixins(args[0]) : args[0] : emptyBase,\n        props = args[hasBase? 1 : 0] || {},\n        staticProps = args[hasBase? 2 : 1],\n        res = props.__constructor || (hasBase && base.prototype.__constructor)?\n            function() {\n                return this.__constructor.apply(this, arguments);\n            } :\n            hasBase?\n                function() {\n                    return base.apply(this, arguments);\n                } :\n                function() {};\n\n    if(!hasBase) {\n        res.prototype = props;\n        res.prototype.__self = res.prototype.constructor = res;\n        return extend(res, staticProps);\n    }\n\n    extend(res, base);\n\n    res.__parent = base;\n\n    var basePtp = base.prototype,\n        resPtp = res.prototype = objCreate(basePtp);\n\n    resPtp.__self = resPtp.constructor = res;\n\n    props && override(basePtp, resPtp, props);\n    staticProps && override(base, res, staticProps);\n\n    return res;\n}\n\ninherit.self = function() {\n    var args = arguments,\n        withMixins = isArray(args[0]),\n        base = withMixins? applyMixins(args[0], args[0][0]) : args[0],\n        props = args[1],\n        staticProps = args[2],\n        basePtp = base.prototype;\n\n    props && override(basePtp, basePtp, props);\n    staticProps && override(base, base, staticProps);\n\n    return base;\n};\n\nvar defineAsGlobal = true;\nif(typeof exports === 'object') {\n    module.exports = inherit;\n    defineAsGlobal = false;\n}\n\nif(typeof modules === 'object') {\n    modules.define('inherit', function(provide) {\n        provide(inherit);\n    });\n    defineAsGlobal = false;\n}\n\nif(typeof define === 'function') {\n    define(function(require, exports, module) {\n        module.exports = inherit;\n    });\n    defineAsGlobal = false;\n}\n\ndefineAsGlobal && (global.inherit = inherit);\n\n})(this);\n","var baseIndexOf = require('../internal/baseIndexOf'),\n    binaryIndex = require('../internal/binaryIndex');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the offset\n * from the end of `array`. If `array` is sorted providing `true` for `fromIndex`\n * performs a faster binary search.\n *\n * @static\n * @memberOf _\n * @category Array\n * @param {Array} array The array to search.\n * @param {*} value The value to search for.\n * @param {boolean|number} [fromIndex=0] The index to search from or `true`\n *  to perform a binary search on a sorted array.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // using `fromIndex`\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n *\n * // performing a binary search\n * _.indexOf([1, 1, 2, 2], 2, true);\n * // => 2\n */\nfunction indexOf(array, value, fromIndex) {\n  var length = array ? array.length : 0;\n  if (!length) {\n    return -1;\n  }\n  if (typeof fromIndex == 'number') {\n    fromIndex = fromIndex < 0 ? nativeMax(length + fromIndex, 0) : fromIndex;\n  } else if (fromIndex) {\n    var index = binaryIndex(array, value);\n    if (index < length &&\n        (value === value ? (value === array[index]) : (array[index] !== array[index]))) {\n      return index;\n    }\n    return -1;\n  }\n  return baseIndexOf(array, value, fromIndex || 0);\n}\n\nmodule.exports = indexOf;\n","/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n  var length = array ? array.length : 0;\n  return length ? array[length - 1] : undefined;\n}\n\nmodule.exports = last;\n","var LazyWrapper = require('../internal/LazyWrapper'),\n    LodashWrapper = require('../internal/LodashWrapper'),\n    baseLodash = require('../internal/baseLodash'),\n    isArray = require('../lang/isArray'),\n    isObjectLike = require('../internal/isObjectLike'),\n    wrapperClone = require('../internal/wrapperClone');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates a `lodash` object which wraps `value` to enable implicit chaining.\n * Methods that operate on and return arrays, collections, and functions can\n * be chained together. Methods that retrieve a single value or may return a\n * primitive value will automatically end the chain returning the unwrapped\n * value. Explicit chaining may be enabled using `_.chain`. The execution of\n * chained methods is lazy, that is, execution is deferred until `_#value`\n * is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion. Shortcut\n * fusion is an optimization strategy which merge iteratee calls; this can help\n * to avoid the creation of intermediate data structures and greatly reduce the\n * number of iteratee executions.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `reverse`, `shift`, `slice`, `sort`,\n * `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `compact`, `drop`, `dropRight`, `dropRightWhile`, `dropWhile`, `filter`,\n * `first`, `initial`, `last`, `map`, `pluck`, `reject`, `rest`, `reverse`,\n * `slice`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, `toArray`,\n * and `where`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `at`, `before`, `bind`, `bindAll`, `bindKey`,\n * `callback`, `chain`, `chunk`, `commit`, `compact`, `concat`, `constant`,\n * `countBy`, `create`, `curry`, `debounce`, `defaults`, `defaultsDeep`,\n * `defer`, `delay`, `difference`, `drop`, `dropRight`, `dropRightWhile`,\n * `dropWhile`, `fill`, `filter`, `flatten`, `flattenDeep`, `flow`, `flowRight`,\n * `forEach`, `forEachRight`, `forIn`, `forInRight`, `forOwn`, `forOwnRight`,\n * `functions`, `groupBy`, `indexBy`, `initial`, `intersection`, `invert`,\n * `invoke`, `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`,\n * `matchesProperty`, `memoize`, `merge`, `method`, `methodOf`, `mixin`,\n * `modArgs`, `negate`, `omit`, `once`, `pairs`, `partial`, `partialRight`,\n * `partition`, `pick`, `plant`, `pluck`, `property`, `propertyOf`, `pull`,\n * `pullAt`, `push`, `range`, `rearg`, `reject`, `remove`, `rest`, `restParam`,\n * `reverse`, `set`, `shuffle`, `slice`, `sort`, `sortBy`, `sortByAll`,\n * `sortByOrder`, `splice`, `spread`, `take`, `takeRight`, `takeRightWhile`,\n * `takeWhile`, `tap`, `throttle`, `thru`, `times`, `toArray`, `toPlainObject`,\n * `transform`, `union`, `uniq`, `unshift`, `unzip`, `unzipWith`, `values`,\n * `valuesIn`, `where`, `without`, `wrap`, `xor`, `zip`, `zipObject`, `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clone`, `cloneDeep`,\n * `deburr`, `endsWith`, `escape`, `escapeRegExp`, `every`, `find`, `findIndex`,\n * `findKey`, `findLast`, `findLastIndex`, `findLastKey`, `findWhere`, `first`,\n * `floor`, `get`, `gt`, `gte`, `has`, `identity`, `includes`, `indexOf`,\n * `inRange`, `isArguments`, `isArray`, `isBoolean`, `isDate`, `isElement`,\n * `isEmpty`, `isEqual`, `isError`, `isFinite` `isFunction`, `isMatch`,\n * `isNative`, `isNaN`, `isNull`, `isNumber`, `isObject`, `isPlainObject`,\n * `isRegExp`, `isString`, `isUndefined`, `isTypedArray`, `join`, `kebabCase`,\n * `last`, `lastIndexOf`, `lt`, `lte`, `max`, `min`, `noConflict`, `noop`,\n * `now`, `pad`, `padLeft`, `padRight`, `parseInt`, `pop`, `random`, `reduce`,\n * `reduceRight`, `repeat`, `result`, `round`, `runInContext`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedLastIndex`, `startCase`,\n * `startsWith`, `sum`, `template`, `trim`, `trimLeft`, `trimRight`, `trunc`,\n * `unescape`, `uniqueId`, `value`, and `words`\n *\n * The wrapper method `sample` will return a wrapped value when `n` is provided,\n * otherwise an unwrapped value is returned.\n *\n * @name _\n * @constructor\n * @category Chain\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // returns an unwrapped value\n * wrapped.reduce(function(total, n) {\n *   return total + n;\n * });\n * // => 6\n *\n * // returns a wrapped value\n * var squares = wrapped.map(function(n) {\n *   return n * n;\n * });\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\nfunction lodash(value) {\n  if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n    if (value instanceof LodashWrapper) {\n      return value;\n    }\n    if (hasOwnProperty.call(value, '__chain__') && hasOwnProperty.call(value, '__wrapped__')) {\n      return wrapperClone(value);\n    }\n  }\n  return new LodashWrapper(value);\n}\n\n// Ensure wrappers are instances of `baseLodash`.\nlodash.prototype = baseLodash.prototype;\n\nmodule.exports = lodash;\n","module.exports = require('./forEach');\n","var baseEach = require('../internal/baseEach'),\n    createFind = require('../internal/createFind');\n\n/**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is bound to `thisArg` and\n * invoked with three arguments: (value, index|key, collection).\n *\n * If a property name is provided for `predicate` the created `_.property`\n * style callback returns the property value of the given element.\n *\n * If a value is also provided for `thisArg` the created `_.matchesProperty`\n * style callback returns `true` for elements that have a matching property\n * value, else `false`.\n *\n * If an object is provided for `predicate` the created `_.matches` style\n * callback returns `true` for elements that have the properties of the given\n * object, else `false`.\n *\n * @static\n * @memberOf _\n * @alias detect\n * @category Collection\n * @param {Array|Object|string} collection The collection to search.\n * @param {Function|Object|string} [predicate=_.identity] The function invoked\n *  per iteration.\n * @param {*} [thisArg] The `this` binding of `predicate`.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n *   { 'user': 'barney',  'age': 36, 'active': true },\n *   { 'user': 'fred',    'age': 40, 'active': false },\n *   { 'user': 'pebbles', 'age': 1,  'active': true }\n * ];\n *\n * _.result(_.find(users, function(chr) {\n *   return chr.age < 40;\n * }), 'user');\n * // => 'barney'\n *\n * // using the `_.matches` callback shorthand\n * _.result(_.find(users, { 'age': 1, 'active': true }), 'user');\n * // => 'pebbles'\n *\n * // using the `_.matchesProperty` callback shorthand\n * _.result(_.find(users, 'active', false), 'user');\n * // => 'fred'\n *\n * // using the `_.property` callback shorthand\n * _.result(_.find(users, 'active'), 'user');\n * // => 'barney'\n */\nvar find = createFind(baseEach);\n\nmodule.exports = find;\n","var arrayEach = require('../internal/arrayEach'),\n    baseEach = require('../internal/baseEach'),\n    createForEach = require('../internal/createForEach');\n\n/**\n * Iterates over elements of `collection` invoking `iteratee` for each element.\n * The `iteratee` is bound to `thisArg` and invoked with three arguments:\n * (value, index|key, collection). Iteratee functions may exit iteration early\n * by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\" property\n * are iterated like arrays. To avoid this behavior `_.forIn` or `_.forOwn`\n * may be used for object iteration.\n *\n * @static\n * @memberOf _\n * @alias each\n * @category Collection\n * @param {Array|Object|string} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [thisArg] The `this` binding of `iteratee`.\n * @returns {Array|Object|string} Returns `collection`.\n * @example\n *\n * _([1, 2]).forEach(function(n) {\n *   console.log(n);\n * }).value();\n * // => logs each value from left to right and returns the array\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(n, key) {\n *   console.log(n, key);\n * });\n * // => logs each value-key pair and returns the object (iteration order is not guaranteed)\n */\nvar forEach = createForEach(arrayEach, baseEach);\n\nmodule.exports = forEach;\n","var baseIndexOf = require('../internal/baseIndexOf'),\n    getLength = require('../internal/getLength'),\n    isArray = require('../lang/isArray'),\n    isIterateeCall = require('../internal/isIterateeCall'),\n    isLength = require('../internal/isLength'),\n    isString = require('../lang/isString'),\n    values = require('../object/values');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Checks if `target` is in `collection` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/6.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the offset\n * from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @alias contains, include\n * @category Collection\n * @param {Array|Object|string} collection The collection to search.\n * @param {*} target The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as a callback for functions like `_.reduce`.\n * @returns {boolean} Returns `true` if a matching element is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'user': 'fred', 'age': 40 }, 'fred');\n * // => true\n *\n * _.includes('pebbles', 'eb');\n * // => true\n */\nfunction includes(collection, target, fromIndex, guard) {\n  var length = collection ? getLength(collection) : 0;\n  if (!isLength(length)) {\n    collection = values(collection);\n    length = collection.length;\n  }\n  if (typeof fromIndex != 'number' || (guard && isIterateeCall(target, fromIndex, guard))) {\n    fromIndex = 0;\n  } else {\n    fromIndex = fromIndex < 0 ? nativeMax(length + fromIndex, 0) : (fromIndex || 0);\n  }\n  return (typeof collection == 'string' || !isArray(collection) && isString(collection))\n    ? (fromIndex <= length && collection.indexOf(target, fromIndex) > -1)\n    : (!!length && baseIndexOf(collection, target, fromIndex) > -1);\n}\n\nmodule.exports = includes;\n","var arrayMap = require('../internal/arrayMap'),\n    baseCallback = require('../internal/baseCallback'),\n    baseMap = require('../internal/baseMap'),\n    isArray = require('../lang/isArray');\n\n/**\n * Creates an array of values by running each element in `collection` through\n * `iteratee`. The `iteratee` is bound to `thisArg` and invoked with three\n * arguments: (value, index|key, collection).\n *\n * If a property name is provided for `iteratee` the created `_.property`\n * style callback returns the property value of the given element.\n *\n * If a value is also provided for `thisArg` the created `_.matchesProperty`\n * style callback returns `true` for elements that have a matching property\n * value, else `false`.\n *\n * If an object is provided for `iteratee` the created `_.matches` style\n * callback returns `true` for elements that have the properties of the given\n * object, else `false`.\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `callback`, `chunk`, `clone`, `create`, `curry`, `curryRight`,\n * `drop`, `dropRight`, `every`, `fill`, `flatten`, `invert`, `max`, `min`,\n * `parseInt`, `slice`, `sortBy`, `take`, `takeRight`, `template`, `trim`,\n * `trimLeft`, `trimRight`, `trunc`, `random`, `range`, `sample`, `some`,\n * `sum`, `uniq`, and `words`\n *\n * @static\n * @memberOf _\n * @alias collect\n * @category Collection\n * @param {Array|Object|string} collection The collection to iterate over.\n * @param {Function|Object|string} [iteratee=_.identity] The function invoked\n *  per iteration.\n * @param {*} [thisArg] The `this` binding of `iteratee`.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function timesThree(n) {\n *   return n * 3;\n * }\n *\n * _.map([1, 2], timesThree);\n * // => [3, 6]\n *\n * _.map({ 'a': 1, 'b': 2 }, timesThree);\n * // => [3, 6] (iteration order is not guaranteed)\n *\n * var users = [\n *   { 'user': 'barney' },\n *   { 'user': 'fred' }\n * ];\n *\n * // using the `_.property` callback shorthand\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\nfunction map(collection, iteratee, thisArg) {\n  var func = isArray(collection) ? arrayMap : baseMap;\n  iteratee = baseCallback(iteratee, thisArg, 3);\n  return func(collection, iteratee);\n}\n\nmodule.exports = map;\n","var getNative = require('../internal/getNative');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeNow = getNative(Date, 'now');\n\n/**\n * Gets the number of milliseconds that have elapsed since the Unix epoch\n * (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @category Date\n * @example\n *\n * _.defer(function(stamp) {\n *   console.log(_.now() - stamp);\n * }, _.now());\n * // => logs the number of milliseconds it took for the deferred function to be invoked\n */\nvar now = nativeNow || function() {\n  return new Date().getTime();\n};\n\nmodule.exports = now;\n","var createWrapper = require('../internal/createWrapper'),\n    replaceHolders = require('../internal/replaceHolders'),\n    restParam = require('./restParam');\n\n/** Used to compose bitmasks for wrapper metadata. */\nvar BIND_FLAG = 1,\n    PARTIAL_FLAG = 32;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and prepends any additional `_.bind` arguments to those provided to the\n * bound function.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind` this method does not set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var greet = function(greeting, punctuation) {\n *   return greeting + ' ' + this.user + punctuation;\n * };\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // using placeholders\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\nvar bind = restParam(function(func, thisArg, partials) {\n  var bitmask = BIND_FLAG;\n  if (partials.length) {\n    var holders = replaceHolders(partials, bind.placeholder);\n    bitmask |= PARTIAL_FLAG;\n  }\n  return createWrapper(func, bitmask, thisArg, partials, holders);\n});\n\n// Assign default placeholders.\nbind.placeholder = {};\n\nmodule.exports = bind;\n","/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as an array.\n *\n * **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/Web/JavaScript/Reference/Functions/rest_parameters).\n *\n * @static\n * @memberOf _\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.restParam(function(what, names) {\n *   return what + ' ' + _.initial(names).join(', ') +\n *     (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\nfunction restParam(func, start) {\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0);\n  return function() {\n    var args = arguments,\n        index = -1,\n        length = nativeMax(args.length - start, 0),\n        rest = Array(length);\n\n    while (++index < length) {\n      rest[index] = args[start + index];\n    }\n    switch (start) {\n      case 0: return func.call(this, rest);\n      case 1: return func.call(this, args[0], rest);\n      case 2: return func.call(this, args[0], args[1], rest);\n    }\n    var otherArgs = Array(start + 1);\n    index = -1;\n    while (++index < start) {\n      otherArgs[index] = args[index];\n    }\n    otherArgs[start] = rest;\n    return func.apply(this, otherArgs);\n  };\n}\n\nmodule.exports = restParam;\n","var baseCreate = require('./baseCreate'),\n    baseLodash = require('./baseLodash');\n\n/** Used as references for `-Infinity` and `Infinity`. */\nvar POSITIVE_INFINITY = Number.POSITIVE_INFINITY;\n\n/**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @param {*} value The value to wrap.\n */\nfunction LazyWrapper(value) {\n  this.__wrapped__ = value;\n  this.__actions__ = [];\n  this.__dir__ = 1;\n  this.__filtered__ = false;\n  this.__iteratees__ = [];\n  this.__takeCount__ = POSITIVE_INFINITY;\n  this.__views__ = [];\n}\n\nLazyWrapper.prototype = baseCreate(baseLodash.prototype);\nLazyWrapper.prototype.constructor = LazyWrapper;\n\nmodule.exports = LazyWrapper;\n","var baseCreate = require('./baseCreate'),\n    baseLodash = require('./baseLodash');\n\n/**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable chaining for all wrapper methods.\n * @param {Array} [actions=[]] Actions to peform to resolve the unwrapped value.\n */\nfunction LodashWrapper(value, chainAll, actions) {\n  this.__wrapped__ = value;\n  this.__actions__ = actions || [];\n  this.__chain__ = !!chainAll;\n}\n\nLodashWrapper.prototype = baseCreate(baseLodash.prototype);\nLodashWrapper.prototype.constructor = LodashWrapper;\n\nmodule.exports = LodashWrapper;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction arrayCopy(source, array) {\n  var index = -1,\n      length = source.length;\n\n  array || (array = Array(length));\n  while (++index < length) {\n    array[index] = source[index];\n  }\n  return array;\n}\n\nmodule.exports = arrayCopy;\n","/**\n * A specialized version of `_.forEach` for arrays without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (iteratee(array[index], index, array) === false) {\n      break;\n    }\n  }\n  return array;\n}\n\nmodule.exports = arrayEach;\n","/**\n * A specialized version of `_.map` for arrays without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\nmodule.exports = arrayMap;\n","/**\n * A specialized version of `_.some` for arrays without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n *  else `false`.\n */\nfunction arraySome(array, predicate) {\n  var index = -1,\n      length = array.length;\n\n  while (++index < length) {\n    if (predicate(array[index], index, array)) {\n      return true;\n    }\n  }\n  return false;\n}\n\nmodule.exports = arraySome;\n","var baseCopy = require('./baseCopy'),\n    keys = require('../object/keys');\n\n/**\n * The base implementation of `_.assign` without support for argument juggling,\n * multiple sources, and `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n  return source == null\n    ? object\n    : baseCopy(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n","var baseMatches = require('./baseMatches'),\n    baseMatchesProperty = require('./baseMatchesProperty'),\n    bindCallback = require('./bindCallback'),\n    identity = require('../utility/identity'),\n    property = require('../utility/property');\n\n/**\n * The base implementation of `_.callback` which supports specifying the\n * number of arguments to provide to `func`.\n *\n * @private\n * @param {*} [func=_.identity] The value to convert to a callback.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {number} [argCount] The number of arguments to provide to `func`.\n * @returns {Function} Returns the callback.\n */\nfunction baseCallback(func, thisArg, argCount) {\n  var type = typeof func;\n  if (type == 'function') {\n    return thisArg === undefined\n      ? func\n      : bindCallback(func, thisArg, argCount);\n  }\n  if (func == null) {\n    return identity;\n  }\n  if (type == 'object') {\n    return baseMatches(func);\n  }\n  return thisArg === undefined\n    ? property(func)\n    : baseMatchesProperty(func, thisArg);\n}\n\nmodule.exports = baseCallback;\n","var arrayCopy = require('./arrayCopy'),\n    arrayEach = require('./arrayEach'),\n    baseAssign = require('./baseAssign'),\n    baseForOwn = require('./baseForOwn'),\n    initCloneArray = require('./initCloneArray'),\n    initCloneByTag = require('./initCloneByTag'),\n    initCloneObject = require('./initCloneObject'),\n    isArray = require('../lang/isArray'),\n    isHostObject = require('./isHostObject'),\n    isObject = require('../lang/isObject');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[boolTag] =\ncloneableTags[dateTag] = cloneableTags[float32Tag] =\ncloneableTags[float64Tag] = cloneableTags[int8Tag] =\ncloneableTags[int16Tag] = cloneableTags[int32Tag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[stringTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[mapTag] = cloneableTags[setTag] =\ncloneableTags[weakMapTag] = false;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * The base implementation of `_.clone` without support for argument juggling\n * and `this` binding `customizer` functions.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @param {Function} [customizer] The function to customize cloning values.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The object `value` belongs to.\n * @param {Array} [stackA=[]] Tracks traversed source objects.\n * @param {Array} [stackB=[]] Associates clones with source counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, isDeep, customizer, key, object, stackA, stackB) {\n  var result;\n  if (customizer) {\n    result = object ? customizer(value, key, object) : customizer(value);\n  }\n  if (result !== undefined) {\n    return result;\n  }\n  if (!isObject(value)) {\n    return value;\n  }\n  var isArr = isArray(value);\n  if (isArr) {\n    result = initCloneArray(value);\n    if (!isDeep) {\n      return arrayCopy(value, result);\n    }\n  } else {\n    var tag = objToString.call(value),\n        isFunc = tag == funcTag;\n\n    if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n      if (isHostObject(value)) {\n        return object ? value : {};\n      }\n      result = initCloneObject(isFunc ? {} : value);\n      if (!isDeep) {\n        return baseAssign(result, value);\n      }\n    } else {\n      return cloneableTags[tag]\n        ? initCloneByTag(value, tag, isDeep)\n        : (object ? value : {});\n    }\n  }\n  // Check for circular references and return its corresponding clone.\n  stackA || (stackA = []);\n  stackB || (stackB = []);\n\n  var length = stackA.length;\n  while (length--) {\n    if (stackA[length] == value) {\n      return stackB[length];\n    }\n  }\n  // Add the source value to the stack of traversed objects and associate it with its clone.\n  stackA.push(value);\n  stackB.push(result);\n\n  // Recursively populate clone (susceptible to call stack limits).\n  (isArr ? arrayEach : baseForOwn)(value, function(subValue, key) {\n    result[key] = baseClone(subValue, isDeep, customizer, key, value, stackA, stackB);\n  });\n  return result;\n}\n\nmodule.exports = baseClone;\n","/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property names to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @returns {Object} Returns `object`.\n */\nfunction baseCopy(source, props, object) {\n  object || (object = {});\n\n  var index = -1,\n      length = props.length;\n\n  while (++index < length) {\n    var key = props[index];\n    object[key] = source[key];\n  }\n  return object;\n}\n\nmodule.exports = baseCopy;\n","var isObject = require('../lang/isObject');\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n  function object() {}\n  return function(prototype) {\n    if (isObject(prototype)) {\n      object.prototype = prototype;\n      var result = new object;\n      object.prototype = undefined;\n    }\n    return result || {};\n  };\n}());\n\nmodule.exports = baseCreate;\n","var baseForOwn = require('./baseForOwn'),\n    createBaseEach = require('./createBaseEach');\n\n/**\n * The base implementation of `_.forEach` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Array|Object|string} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object|string} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nmodule.exports = baseEach;\n","/**\n * The base implementation of `_.find`, `_.findLast`, `_.findKey`, and `_.findLastKey`,\n * without support for callback shorthands and `this` binding, which iterates\n * over `collection` using the provided `eachFunc`.\n *\n * @private\n * @param {Array|Object|string} collection The collection to search.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @param {boolean} [retKey] Specify returning the key of the found element\n *  instead of the element itself.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\nfunction baseFind(collection, predicate, eachFunc, retKey) {\n  var result;\n  eachFunc(collection, function(value, key, collection) {\n    if (predicate(value, key, collection)) {\n      result = retKey ? key : value;\n      return false;\n    }\n  });\n  return result;\n}\n\nmodule.exports = baseFind;\n","/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for callback shorthands and `this` binding.\n *\n * @private\n * @param {Array} array The array to search.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromRight) {\n  var length = array.length,\n      index = fromRight ? length : -1;\n\n  while ((fromRight ? index-- : ++index < length)) {\n    if (predicate(array[index], index, array)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = baseFindIndex;\n","var createBaseFor = require('./createBaseFor');\n\n/**\n * The base implementation of `baseForIn` and `baseForOwn` which iterates\n * over `object` properties returned by `keysFunc` invoking `iteratee` for\n * each property. Iteratee functions may exit iteration early by explicitly\n * returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","var baseFor = require('./baseFor'),\n    keysIn = require('../object/keysIn');\n\n/**\n * The base implementation of `_.forIn` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForIn(object, iteratee) {\n  return baseFor(object, iteratee, keysIn);\n}\n\nmodule.exports = baseForIn;\n","var baseFor = require('./baseFor'),\n    keys = require('../object/keys');\n\n/**\n * The base implementation of `_.forOwn` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n  return baseFor(object, iteratee, keys);\n}\n\nmodule.exports = baseForOwn;\n","var toObject = require('./toObject');\n\n/**\n * The base implementation of `get` without support for string paths\n * and default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path of the property to get.\n * @param {string} [pathKey] The key representation of path.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path, pathKey) {\n  if (object == null) {\n    return;\n  }\n  object = toObject(object);\n  if (pathKey !== undefined && pathKey in object) {\n    path = [pathKey];\n  }\n  var index = 0,\n      length = path.length;\n\n  while (object != null && index < length) {\n    object = toObject(object)[path[index++]];\n  }\n  return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var indexOfNaN = require('./indexOfNaN');\n\n/**\n * The base implementation of `_.indexOf` without support for binary searches.\n *\n * @private\n * @param {Array} array The array to search.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n  if (value !== value) {\n    return indexOfNaN(array, fromIndex);\n  }\n  var index = fromIndex - 1,\n      length = array.length;\n\n  while (++index < length) {\n    if (array[index] === value) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = baseIndexOf;\n","var baseIsEqualDeep = require('./baseIsEqualDeep'),\n    isObject = require('../lang/isObject'),\n    isObjectLike = require('./isObjectLike');\n\n/**\n * The base implementation of `_.isEqual` without support for `this` binding\n * `customizer` functions.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparing values.\n * @param {boolean} [isLoose] Specify performing partial comparisons.\n * @param {Array} [stackA] Tracks traversed `value` objects.\n * @param {Array} [stackB] Tracks traversed `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, customizer, isLoose, stackA, stackB) {\n  if (value === other) {\n    return true;\n  }\n  if (value == null || other == null || (!isObject(value) && !isObjectLike(other))) {\n    return value !== value && other !== other;\n  }\n  return baseIsEqualDeep(value, other, baseIsEqual, customizer, isLoose, stackA, stackB);\n}\n\nmodule.exports = baseIsEqual;\n","var equalArrays = require('./equalArrays'),\n    equalByTag = require('./equalByTag'),\n    equalObjects = require('./equalObjects'),\n    isArray = require('../lang/isArray'),\n    isHostObject = require('./isHostObject'),\n    isTypedArray = require('../lang/isTypedArray');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    objectTag = '[object Object]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} [customizer] The function to customize comparing objects.\n * @param {boolean} [isLoose] Specify performing partial comparisons.\n * @param {Array} [stackA=[]] Tracks traversed `value` objects.\n * @param {Array} [stackB=[]] Tracks traversed `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, equalFunc, customizer, isLoose, stackA, stackB) {\n  var objIsArr = isArray(object),\n      othIsArr = isArray(other),\n      objTag = arrayTag,\n      othTag = arrayTag;\n\n  if (!objIsArr) {\n    objTag = objToString.call(object);\n    if (objTag == argsTag) {\n      objTag = objectTag;\n    } else if (objTag != objectTag) {\n      objIsArr = isTypedArray(object);\n    }\n  }\n  if (!othIsArr) {\n    othTag = objToString.call(other);\n    if (othTag == argsTag) {\n      othTag = objectTag;\n    } else if (othTag != objectTag) {\n      othIsArr = isTypedArray(other);\n    }\n  }\n  var objIsObj = objTag == objectTag && !isHostObject(object),\n      othIsObj = othTag == objectTag && !isHostObject(other),\n      isSameTag = objTag == othTag;\n\n  if (isSameTag && !(objIsArr || objIsObj)) {\n    return equalByTag(object, other, objTag);\n  }\n  if (!isLoose) {\n    var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n        othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n    if (objIsWrapped || othIsWrapped) {\n      return equalFunc(objIsWrapped ? object.value() : object, othIsWrapped ? other.value() : other, customizer, isLoose, stackA, stackB);\n    }\n  }\n  if (!isSameTag) {\n    return false;\n  }\n  // Assume cyclic values are equal.\n  // For more information on detecting circular references see https://es5.github.io/#JO.\n  stackA || (stackA = []);\n  stackB || (stackB = []);\n\n  var length = stackA.length;\n  while (length--) {\n    if (stackA[length] == object) {\n      return stackB[length] == other;\n    }\n  }\n  // Add `object` and `other` to the stack of traversed objects.\n  stackA.push(object);\n  stackB.push(other);\n\n  var result = (objIsArr ? equalArrays : equalObjects)(object, other, equalFunc, customizer, isLoose, stackA, stackB);\n\n  stackA.pop();\n  stackB.pop();\n\n  return result;\n}\n\nmodule.exports = baseIsEqualDeep;\n","var baseIsEqual = require('./baseIsEqual'),\n    toObject = require('./toObject');\n\n/**\n * The base implementation of `_.isMatch` without support for callback\n * shorthands and `this` binding.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} matchData The propery names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparing objects.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, matchData, customizer) {\n  var index = matchData.length,\n      length = index,\n      noCustomizer = !customizer;\n\n  if (object == null) {\n    return !length;\n  }\n  object = toObject(object);\n  while (index--) {\n    var data = matchData[index];\n    if ((noCustomizer && data[2])\n          ? data[1] !== object[data[0]]\n          : !(data[0] in object)\n        ) {\n      return false;\n    }\n  }\n  while (++index < length) {\n    data = matchData[index];\n    var key = data[0],\n        objValue = object[key],\n        srcValue = data[1];\n\n    if (noCustomizer && data[2]) {\n      if (objValue === undefined && !(key in object)) {\n        return false;\n      }\n    } else {\n      var result = customizer ? customizer(objValue, srcValue, key) : undefined;\n      if (!(result === undefined ? baseIsEqual(srcValue, objValue, customizer, true) : result)) {\n        return false;\n      }\n    }\n  }\n  return true;\n}\n\nmodule.exports = baseIsMatch;\n","/**\n * The function whose prototype all chaining wrappers inherit from.\n *\n * @private\n */\nfunction baseLodash() {\n  // No operation performed.\n}\n\nmodule.exports = baseLodash;\n","var baseEach = require('./baseEach'),\n    isArrayLike = require('./isArrayLike');\n\n/**\n * The base implementation of `_.map` without support for callback shorthands\n * and `this` binding.\n *\n * @private\n * @param {Array|Object|string} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction baseMap(collection, iteratee) {\n  var index = -1,\n      result = isArrayLike(collection) ? Array(collection.length) : [];\n\n  baseEach(collection, function(value, key, collection) {\n    result[++index] = iteratee(value, key, collection);\n  });\n  return result;\n}\n\nmodule.exports = baseMap;\n","var baseIsMatch = require('./baseIsMatch'),\n    getMatchData = require('./getMatchData'),\n    toObject = require('./toObject');\n\n/**\n * The base implementation of `_.matches` which does not clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new function.\n */\nfunction baseMatches(source) {\n  var matchData = getMatchData(source);\n  if (matchData.length == 1 && matchData[0][2]) {\n    var key = matchData[0][0],\n        value = matchData[0][1];\n\n    return function(object) {\n      if (object == null) {\n        return false;\n      }\n      object = toObject(object);\n      return object[key] === value && (value !== undefined || (key in object));\n    };\n  }\n  return function(object) {\n    return baseIsMatch(object, matchData);\n  };\n}\n\nmodule.exports = baseMatches;\n","var baseGet = require('./baseGet'),\n    baseIsEqual = require('./baseIsEqual'),\n    baseSlice = require('./baseSlice'),\n    isArray = require('../lang/isArray'),\n    isKey = require('./isKey'),\n    isStrictComparable = require('./isStrictComparable'),\n    last = require('../array/last'),\n    toObject = require('./toObject'),\n    toPath = require('./toPath');\n\n/**\n * The base implementation of `_.matchesProperty` which does not clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to compare.\n * @returns {Function} Returns the new function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n  var isArr = isArray(path),\n      isCommon = isKey(path) && isStrictComparable(srcValue),\n      pathKey = (path + '');\n\n  path = toPath(path);\n  return function(object) {\n    if (object == null) {\n      return false;\n    }\n    var key = pathKey;\n    object = toObject(object);\n    if ((isArr || !isCommon) && !(key in object)) {\n      object = path.length == 1 ? object : baseGet(object, baseSlice(path, 0, -1));\n      if (object == null) {\n        return false;\n      }\n      key = last(path);\n      object = toObject(object);\n    }\n    return object[key] === srcValue\n      ? (srcValue !== undefined || (key in object))\n      : baseIsEqual(srcValue, object[key], undefined, true);\n  };\n}\n\nmodule.exports = baseMatchesProperty;\n","var toObject = require('./toObject');\n\n/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction baseProperty(key) {\n  return function(object) {\n    return object == null ? undefined : toObject(object)[key];\n  };\n}\n\nmodule.exports = baseProperty;\n","var baseGet = require('./baseGet'),\n    toPath = require('./toPath');\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new function.\n */\nfunction basePropertyDeep(path) {\n  var pathKey = (path + '');\n  path = toPath(path);\n  return function(object) {\n    return baseGet(object, path, pathKey);\n  };\n}\n\nmodule.exports = basePropertyDeep;\n","var identity = require('../utility/identity'),\n    metaMap = require('./metaMap');\n\n/**\n * The base implementation of `setData` without support for hot loop detection.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar baseSetData = !metaMap ? identity : function(func, data) {\n  metaMap.set(func, data);\n  return func;\n};\n\nmodule.exports = baseSetData;\n","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n  var index = -1,\n      length = array.length;\n\n  start = start == null ? 0 : (+start || 0);\n  if (start < 0) {\n    start = -start > length ? 0 : (length + start);\n  }\n  end = (end === undefined || end > length) ? length : (+end || 0);\n  if (end < 0) {\n    end += length;\n  }\n  length = start > end ? 0 : ((end - start) >>> 0);\n  start >>>= 0;\n\n  var result = Array(length);\n  while (++index < length) {\n    result[index] = array[index + start];\n  }\n  return result;\n}\n\nmodule.exports = baseSlice;\n","/**\n * Converts `value` to a string if it's not one. An empty string is returned\n * for `null` or `undefined` values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n  return value == null ? '' : (value + '');\n}\n\nmodule.exports = baseToString;\n","/**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\nfunction baseValues(object, props) {\n  var index = -1,\n      length = props.length,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = object[props[index]];\n  }\n  return result;\n}\n\nmodule.exports = baseValues;\n","var binaryIndexBy = require('./binaryIndexBy'),\n    identity = require('../utility/identity');\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295,\n    HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n/**\n * Performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n */\nfunction binaryIndex(array, value, retHighest) {\n  var low = 0,\n      high = array ? array.length : low;\n\n  if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n    while (low < high) {\n      var mid = (low + high) >>> 1,\n          computed = array[mid];\n\n      if ((retHighest ? (computed <= value) : (computed < value)) && computed !== null) {\n        low = mid + 1;\n      } else {\n        high = mid;\n      }\n    }\n    return high;\n  }\n  return binaryIndexBy(array, value, identity, retHighest);\n}\n\nmodule.exports = binaryIndex;\n","/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeFloor = Math.floor,\n    nativeMin = Math.min;\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295,\n    MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1;\n\n/**\n * This function is like `binaryIndex` except that it invokes `iteratee` for\n * `value` and each element of `array` to compute their sort ranking. The\n * iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n *  into `array`.\n */\nfunction binaryIndexBy(array, value, iteratee, retHighest) {\n  value = iteratee(value);\n\n  var low = 0,\n      high = array ? array.length : 0,\n      valIsNaN = value !== value,\n      valIsNull = value === null,\n      valIsUndef = value === undefined;\n\n  while (low < high) {\n    var mid = nativeFloor((low + high) / 2),\n        computed = iteratee(array[mid]),\n        isDef = computed !== undefined,\n        isReflexive = computed === computed;\n\n    if (valIsNaN) {\n      var setLow = isReflexive || retHighest;\n    } else if (valIsNull) {\n      setLow = isReflexive && isDef && (retHighest || computed != null);\n    } else if (valIsUndef) {\n      setLow = isReflexive && (retHighest || isDef);\n    } else if (computed == null) {\n      setLow = false;\n    } else {\n      setLow = retHighest ? (computed <= value) : (computed < value);\n    }\n    if (setLow) {\n      low = mid + 1;\n    } else {\n      high = mid;\n    }\n  }\n  return nativeMin(high, MAX_ARRAY_INDEX);\n}\n\nmodule.exports = binaryIndexBy;\n","var identity = require('../utility/identity');\n\n/**\n * A specialized version of `baseCallback` which only supports `this` binding\n * and specifying the number of arguments to provide to `func`.\n *\n * @private\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {number} [argCount] The number of arguments to provide to `func`.\n * @returns {Function} Returns the callback.\n */\nfunction bindCallback(func, thisArg, argCount) {\n  if (typeof func != 'function') {\n    return identity;\n  }\n  if (thisArg === undefined) {\n    return func;\n  }\n  switch (argCount) {\n    case 1: return function(value) {\n      return func.call(thisArg, value);\n    };\n    case 3: return function(value, index, collection) {\n      return func.call(thisArg, value, index, collection);\n    };\n    case 4: return function(accumulator, value, index, collection) {\n      return func.call(thisArg, accumulator, value, index, collection);\n    };\n    case 5: return function(value, other, key, object, source) {\n      return func.call(thisArg, value, other, key, object, source);\n    };\n  }\n  return function() {\n    return func.apply(thisArg, arguments);\n  };\n}\n\nmodule.exports = bindCallback;\n","(function (global){\n/** Native method references. */\nvar ArrayBuffer = global.ArrayBuffer,\n    Uint8Array = global.Uint8Array;\n\n/**\n * Creates a clone of the given array buffer.\n *\n * @private\n * @param {ArrayBuffer} buffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction bufferClone(buffer) {\n  var result = new ArrayBuffer(buffer.byteLength),\n      view = new Uint8Array(result);\n\n  view.set(new Uint8Array(buffer));\n  return result;\n}\n\nmodule.exports = bufferClone;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2J1ZmZlckNsb25lLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiZ2VuZXJhdGVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBOYXRpdmUgbWV0aG9kIHJlZmVyZW5jZXMuICovXG52YXIgQXJyYXlCdWZmZXIgPSBnbG9iYWwuQXJyYXlCdWZmZXIsXG4gICAgVWludDhBcnJheSA9IGdsb2JhbC5VaW50OEFycmF5O1xuXG4vKipcbiAqIENyZWF0ZXMgYSBjbG9uZSBvZiB0aGUgZ2l2ZW4gYXJyYXkgYnVmZmVyLlxuICpcbiAqIEBwcml2YXRlXG4gKiBAcGFyYW0ge0FycmF5QnVmZmVyfSBidWZmZXIgVGhlIGFycmF5IGJ1ZmZlciB0byBjbG9uZS5cbiAqIEByZXR1cm5zIHtBcnJheUJ1ZmZlcn0gUmV0dXJucyB0aGUgY2xvbmVkIGFycmF5IGJ1ZmZlci5cbiAqL1xuZnVuY3Rpb24gYnVmZmVyQ2xvbmUoYnVmZmVyKSB7XG4gIHZhciByZXN1bHQgPSBuZXcgQXJyYXlCdWZmZXIoYnVmZmVyLmJ5dGVMZW5ndGgpLFxuICAgICAgdmlldyA9IG5ldyBVaW50OEFycmF5KHJlc3VsdCk7XG5cbiAgdmlldy5zZXQobmV3IFVpbnQ4QXJyYXkoYnVmZmVyKSk7XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gYnVmZmVyQ2xvbmU7XG4iXX0=","/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array|Object} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgs(args, partials, holders) {\n  var holdersLength = holders.length,\n      argsIndex = -1,\n      argsLength = nativeMax(args.length - holdersLength, 0),\n      leftIndex = -1,\n      leftLength = partials.length,\n      result = Array(leftLength + argsLength);\n\n  while (++leftIndex < leftLength) {\n    result[leftIndex] = partials[leftIndex];\n  }\n  while (++argsIndex < holdersLength) {\n    result[holders[argsIndex]] = args[argsIndex];\n  }\n  while (argsLength--) {\n    result[leftIndex++] = args[argsIndex++];\n  }\n  return result;\n}\n\nmodule.exports = composeArgs;\n","/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array|Object} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgsRight(args, partials, holders) {\n  var holdersIndex = -1,\n      holdersLength = holders.length,\n      argsIndex = -1,\n      argsLength = nativeMax(args.length - holdersLength, 0),\n      rightIndex = -1,\n      rightLength = partials.length,\n      result = Array(argsLength + rightLength);\n\n  while (++argsIndex < argsLength) {\n    result[argsIndex] = args[argsIndex];\n  }\n  var offset = argsIndex;\n  while (++rightIndex < rightLength) {\n    result[offset + rightIndex] = partials[rightIndex];\n  }\n  while (++holdersIndex < holdersLength) {\n    result[offset + holders[holdersIndex]] = args[argsIndex++];\n  }\n  return result;\n}\n\nmodule.exports = composeArgsRight;\n","var getLength = require('./getLength'),\n    isLength = require('./isLength'),\n    toObject = require('./toObject');\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n  return function(collection, iteratee) {\n    var length = collection ? getLength(collection) : 0;\n    if (!isLength(length)) {\n      return eachFunc(collection, iteratee);\n    }\n    var index = fromRight ? length : -1,\n        iterable = toObject(collection);\n\n    while ((fromRight ? index-- : ++index < length)) {\n      if (iteratee(iterable[index], index, iterable) === false) {\n        break;\n      }\n    }\n    return collection;\n  };\n}\n\nmodule.exports = createBaseEach;\n","var toObject = require('./toObject');\n\n/**\n * Creates a base function for `_.forIn` or `_.forInRight`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n  return function(object, iteratee, keysFunc) {\n    var iterable = toObject(object),\n        props = keysFunc(object),\n        length = props.length,\n        index = fromRight ? length : -1;\n\n    while ((fromRight ? index-- : ++index < length)) {\n      var key = props[index];\n      if (iteratee(iterable[key], key, iterable) === false) {\n        break;\n      }\n    }\n    return object;\n  };\n}\n\nmodule.exports = createBaseFor;\n","(function (global){\nvar createCtorWrapper = require('./createCtorWrapper');\n\n/**\n * Creates a function that wraps `func` and invokes it with the `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to bind.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new bound function.\n */\nfunction createBindWrapper(func, thisArg) {\n  var Ctor = createCtorWrapper(func);\n\n  function wrapper() {\n    var fn = (this && this !== global && this instanceof wrapper) ? Ctor : func;\n    return fn.apply(thisArg, arguments);\n  }\n  return wrapper;\n}\n\nmodule.exports = createBindWrapper;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZUJpbmRXcmFwcGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyk7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIGFuZCBpbnZva2VzIGl0IHdpdGggdGhlIGB0aGlzYFxuICogYmluZGluZyBvZiBgdGhpc0FyZ2AuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb259IGZ1bmMgVGhlIGZ1bmN0aW9uIHRvIGJpbmQuXG4gKiBAcGFyYW0geyp9IFt0aGlzQXJnXSBUaGUgYHRoaXNgIGJpbmRpbmcgb2YgYGZ1bmNgLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgYm91bmQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUJpbmRXcmFwcGVyKGZ1bmMsIHRoaXNBcmcpIHtcbiAgdmFyIEN0b3IgPSBjcmVhdGVDdG9yV3JhcHBlcihmdW5jKTtcblxuICBmdW5jdGlvbiB3cmFwcGVyKCkge1xuICAgIHZhciBmbiA9ICh0aGlzICYmIHRoaXMgIT09IGdsb2JhbCAmJiB0aGlzIGluc3RhbmNlb2Ygd3JhcHBlcikgPyBDdG9yIDogZnVuYztcbiAgICByZXR1cm4gZm4uYXBwbHkodGhpc0FyZywgYXJndW1lbnRzKTtcbiAgfVxuICByZXR1cm4gd3JhcHBlcjtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBjcmVhdGVCaW5kV3JhcHBlcjtcbiJdfQ==","var baseCreate = require('./baseCreate'),\n    isObject = require('../lang/isObject');\n\n/**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createCtorWrapper(Ctor) {\n  return function() {\n    // Use a `switch` statement to work with class constructors.\n    // See http://ecma-international.org/ecma-262/6.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n    // for more details.\n    var args = arguments;\n    switch (args.length) {\n      case 0: return new Ctor;\n      case 1: return new Ctor(args[0]);\n      case 2: return new Ctor(args[0], args[1]);\n      case 3: return new Ctor(args[0], args[1], args[2]);\n      case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n      case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n      case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n      case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n    }\n    var thisBinding = baseCreate(Ctor.prototype),\n        result = Ctor.apply(thisBinding, args);\n\n    // Mimic the constructor's `return` behavior.\n    // See https://es5.github.io/#x13.2.2 for more details.\n    return isObject(result) ? result : thisBinding;\n  };\n}\n\nmodule.exports = createCtorWrapper;\n","var baseCallback = require('./baseCallback'),\n    baseFind = require('./baseFind'),\n    baseFindIndex = require('./baseFindIndex'),\n    isArray = require('../lang/isArray');\n\n/**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new find function.\n */\nfunction createFind(eachFunc, fromRight) {\n  return function(collection, predicate, thisArg) {\n    predicate = baseCallback(predicate, thisArg, 3);\n    if (isArray(collection)) {\n      var index = baseFindIndex(collection, predicate, fromRight);\n      return index > -1 ? collection[index] : undefined;\n    }\n    return baseFind(collection, predicate, eachFunc);\n  };\n}\n\nmodule.exports = createFind;\n","var bindCallback = require('./bindCallback'),\n    isArray = require('../lang/isArray');\n\n/**\n * Creates a function for `_.forEach` or `_.forEachRight`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over an array.\n * @param {Function} eachFunc The function to iterate over a collection.\n * @returns {Function} Returns the new each function.\n */\nfunction createForEach(arrayFunc, eachFunc) {\n  return function(collection, iteratee, thisArg) {\n    return (typeof iteratee == 'function' && thisArg === undefined && isArray(collection))\n      ? arrayFunc(collection, iteratee)\n      : eachFunc(collection, bindCallback(iteratee, thisArg, 3));\n  };\n}\n\nmodule.exports = createForEach;\n","(function (global){\nvar arrayCopy = require('./arrayCopy'),\n    composeArgs = require('./composeArgs'),\n    composeArgsRight = require('./composeArgsRight'),\n    createCtorWrapper = require('./createCtorWrapper'),\n    isLaziable = require('./isLaziable'),\n    reorder = require('./reorder'),\n    replaceHolders = require('./replaceHolders'),\n    setData = require('./setData');\n\n/** Used to compose bitmasks for wrapper metadata. */\nvar BIND_FLAG = 1,\n    BIND_KEY_FLAG = 2,\n    CURRY_BOUND_FLAG = 4,\n    CURRY_FLAG = 8,\n    CURRY_RIGHT_FLAG = 16,\n    PARTIAL_FLAG = 32,\n    PARTIAL_RIGHT_FLAG = 64,\n    ARY_FLAG = 128;\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that wraps `func` and invokes it with optional `this`\n * binding of, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to reference.\n * @param {number} bitmask The bitmask of flags. See `createWrapper` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createHybridWrapper(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n  var isAry = bitmask & ARY_FLAG,\n      isBind = bitmask & BIND_FLAG,\n      isBindKey = bitmask & BIND_KEY_FLAG,\n      isCurry = bitmask & CURRY_FLAG,\n      isCurryBound = bitmask & CURRY_BOUND_FLAG,\n      isCurryRight = bitmask & CURRY_RIGHT_FLAG,\n      Ctor = isBindKey ? undefined : createCtorWrapper(func);\n\n  function wrapper() {\n    // Avoid `arguments` object use disqualifying optimizations by\n    // converting it to an array before providing it to other functions.\n    var length = arguments.length,\n        index = length,\n        args = Array(length);\n\n    while (index--) {\n      args[index] = arguments[index];\n    }\n    if (partials) {\n      args = composeArgs(args, partials, holders);\n    }\n    if (partialsRight) {\n      args = composeArgsRight(args, partialsRight, holdersRight);\n    }\n    if (isCurry || isCurryRight) {\n      var placeholder = wrapper.placeholder,\n          argsHolders = replaceHolders(args, placeholder);\n\n      length -= argsHolders.length;\n      if (length < arity) {\n        var newArgPos = argPos ? arrayCopy(argPos) : undefined,\n            newArity = nativeMax(arity - length, 0),\n            newsHolders = isCurry ? argsHolders : undefined,\n            newHoldersRight = isCurry ? undefined : argsHolders,\n            newPartials = isCurry ? args : undefined,\n            newPartialsRight = isCurry ? undefined : args;\n\n        bitmask |= (isCurry ? PARTIAL_FLAG : PARTIAL_RIGHT_FLAG);\n        bitmask &= ~(isCurry ? PARTIAL_RIGHT_FLAG : PARTIAL_FLAG);\n\n        if (!isCurryBound) {\n          bitmask &= ~(BIND_FLAG | BIND_KEY_FLAG);\n        }\n        var newData = [func, bitmask, thisArg, newPartials, newsHolders, newPartialsRight, newHoldersRight, newArgPos, ary, newArity],\n            result = createHybridWrapper.apply(undefined, newData);\n\n        if (isLaziable(func)) {\n          setData(result, newData);\n        }\n        result.placeholder = placeholder;\n        return result;\n      }\n    }\n    var thisBinding = isBind ? thisArg : this,\n        fn = isBindKey ? thisBinding[func] : func;\n\n    if (argPos) {\n      args = reorder(args, argPos);\n    }\n    if (isAry && ary < args.length) {\n      args.length = ary;\n    }\n    if (this && this !== global && this instanceof wrapper) {\n      fn = Ctor || createCtorWrapper(func);\n    }\n    return fn.apply(thisBinding, args);\n  }\n  return wrapper;\n}\n\nmodule.exports = createHybridWrapper;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZUh5YnJpZFdyYXBwZXIuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgYXJyYXlDb3B5ID0gcmVxdWlyZSgnLi9hcnJheUNvcHknKSxcbiAgICBjb21wb3NlQXJncyA9IHJlcXVpcmUoJy4vY29tcG9zZUFyZ3MnKSxcbiAgICBjb21wb3NlQXJnc1JpZ2h0ID0gcmVxdWlyZSgnLi9jb21wb3NlQXJnc1JpZ2h0JyksXG4gICAgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyksXG4gICAgaXNMYXppYWJsZSA9IHJlcXVpcmUoJy4vaXNMYXppYWJsZScpLFxuICAgIHJlb3JkZXIgPSByZXF1aXJlKCcuL3Jlb3JkZXInKSxcbiAgICByZXBsYWNlSG9sZGVycyA9IHJlcXVpcmUoJy4vcmVwbGFjZUhvbGRlcnMnKSxcbiAgICBzZXREYXRhID0gcmVxdWlyZSgnLi9zZXREYXRhJyk7XG5cbi8qKiBVc2VkIHRvIGNvbXBvc2UgYml0bWFza3MgZm9yIHdyYXBwZXIgbWV0YWRhdGEuICovXG52YXIgQklORF9GTEFHID0gMSxcbiAgICBCSU5EX0tFWV9GTEFHID0gMixcbiAgICBDVVJSWV9CT1VORF9GTEFHID0gNCxcbiAgICBDVVJSWV9GTEFHID0gOCxcbiAgICBDVVJSWV9SSUdIVF9GTEFHID0gMTYsXG4gICAgUEFSVElBTF9GTEFHID0gMzIsXG4gICAgUEFSVElBTF9SSUdIVF9GTEFHID0gNjQsXG4gICAgQVJZX0ZMQUcgPSAxMjg7XG5cbi8qIE5hdGl2ZSBtZXRob2QgcmVmZXJlbmNlcyBmb3IgdGhvc2Ugd2l0aCB0aGUgc2FtZSBuYW1lIGFzIG90aGVyIGBsb2Rhc2hgIG1ldGhvZHMuICovXG52YXIgbmF0aXZlTWF4ID0gTWF0aC5tYXg7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGZ1bmN0aW9uIHRoYXQgd3JhcHMgYGZ1bmNgIGFuZCBpbnZva2VzIGl0IHdpdGggb3B0aW9uYWwgYHRoaXNgXG4gKiBiaW5kaW5nIG9mLCBwYXJ0aWFsIGFwcGxpY2F0aW9uLCBhbmQgY3VycnlpbmcuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7RnVuY3Rpb258c3RyaW5nfSBmdW5jIFRoZSBmdW5jdGlvbiBvciBtZXRob2QgbmFtZSB0byByZWZlcmVuY2UuXG4gKiBAcGFyYW0ge251bWJlcn0gYml0bWFzayBUaGUgYml0bWFzayBvZiBmbGFncy4gU2VlIGBjcmVhdGVXcmFwcGVyYCBmb3IgbW9yZSBkZXRhaWxzLlxuICogQHBhcmFtIHsqfSBbdGhpc0FyZ10gVGhlIGB0aGlzYCBiaW5kaW5nIG9mIGBmdW5jYC5cbiAqIEBwYXJhbSB7QXJyYXl9IFtwYXJ0aWFsc10gVGhlIGFyZ3VtZW50cyB0byBwcmVwZW5kIHRvIHRob3NlIHByb3ZpZGVkIHRvIHRoZSBuZXcgZnVuY3Rpb24uXG4gKiBAcGFyYW0ge0FycmF5fSBbaG9sZGVyc10gVGhlIGBwYXJ0aWFsc2AgcGxhY2Vob2xkZXIgaW5kZXhlcy5cbiAqIEBwYXJhbSB7QXJyYXl9IFtwYXJ0aWFsc1JpZ2h0XSBUaGUgYXJndW1lbnRzIHRvIGFwcGVuZCB0byB0aG9zZSBwcm92aWRlZCB0byB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHBhcmFtIHtBcnJheX0gW2hvbGRlcnNSaWdodF0gVGhlIGBwYXJ0aWFsc1JpZ2h0YCBwbGFjZWhvbGRlciBpbmRleGVzLlxuICogQHBhcmFtIHtBcnJheX0gW2FyZ1Bvc10gVGhlIGFyZ3VtZW50IHBvc2l0aW9ucyBvZiB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHBhcmFtIHtudW1iZXJ9IFthcnldIFRoZSBhcml0eSBjYXAgb2YgYGZ1bmNgLlxuICogQHBhcmFtIHtudW1iZXJ9IFthcml0eV0gVGhlIGFyaXR5IG9mIGBmdW5jYC5cbiAqIEByZXR1cm5zIHtGdW5jdGlvbn0gUmV0dXJucyB0aGUgbmV3IHdyYXBwZWQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZUh5YnJpZFdyYXBwZXIoZnVuYywgYml0bWFzaywgdGhpc0FyZywgcGFydGlhbHMsIGhvbGRlcnMsIHBhcnRpYWxzUmlnaHQsIGhvbGRlcnNSaWdodCwgYXJnUG9zLCBhcnksIGFyaXR5KSB7XG4gIHZhciBpc0FyeSA9IGJpdG1hc2sgJiBBUllfRkxBRyxcbiAgICAgIGlzQmluZCA9IGJpdG1hc2sgJiBCSU5EX0ZMQUcsXG4gICAgICBpc0JpbmRLZXkgPSBiaXRtYXNrICYgQklORF9LRVlfRkxBRyxcbiAgICAgIGlzQ3VycnkgPSBiaXRtYXNrICYgQ1VSUllfRkxBRyxcbiAgICAgIGlzQ3VycnlCb3VuZCA9IGJpdG1hc2sgJiBDVVJSWV9CT1VORF9GTEFHLFxuICAgICAgaXNDdXJyeVJpZ2h0ID0gYml0bWFzayAmIENVUlJZX1JJR0hUX0ZMQUcsXG4gICAgICBDdG9yID0gaXNCaW5kS2V5ID8gdW5kZWZpbmVkIDogY3JlYXRlQ3RvcldyYXBwZXIoZnVuYyk7XG5cbiAgZnVuY3Rpb24gd3JhcHBlcigpIHtcbiAgICAvLyBBdm9pZCBgYXJndW1lbnRzYCBvYmplY3QgdXNlIGRpc3F1YWxpZnlpbmcgb3B0aW1pemF0aW9ucyBieVxuICAgIC8vIGNvbnZlcnRpbmcgaXQgdG8gYW4gYXJyYXkgYmVmb3JlIHByb3ZpZGluZyBpdCB0byBvdGhlciBmdW5jdGlvbnMuXG4gICAgdmFyIGxlbmd0aCA9IGFyZ3VtZW50cy5sZW5ndGgsXG4gICAgICAgIGluZGV4ID0gbGVuZ3RoLFxuICAgICAgICBhcmdzID0gQXJyYXkobGVuZ3RoKTtcblxuICAgIHdoaWxlIChpbmRleC0tKSB7XG4gICAgICBhcmdzW2luZGV4XSA9IGFyZ3VtZW50c1tpbmRleF07XG4gICAgfVxuICAgIGlmIChwYXJ0aWFscykge1xuICAgICAgYXJncyA9IGNvbXBvc2VBcmdzKGFyZ3MsIHBhcnRpYWxzLCBob2xkZXJzKTtcbiAgICB9XG4gICAgaWYgKHBhcnRpYWxzUmlnaHQpIHtcbiAgICAgIGFyZ3MgPSBjb21wb3NlQXJnc1JpZ2h0KGFyZ3MsIHBhcnRpYWxzUmlnaHQsIGhvbGRlcnNSaWdodCk7XG4gICAgfVxuICAgIGlmIChpc0N1cnJ5IHx8IGlzQ3VycnlSaWdodCkge1xuICAgICAgdmFyIHBsYWNlaG9sZGVyID0gd3JhcHBlci5wbGFjZWhvbGRlcixcbiAgICAgICAgICBhcmdzSG9sZGVycyA9IHJlcGxhY2VIb2xkZXJzKGFyZ3MsIHBsYWNlaG9sZGVyKTtcblxuICAgICAgbGVuZ3RoIC09IGFyZ3NIb2xkZXJzLmxlbmd0aDtcbiAgICAgIGlmIChsZW5ndGggPCBhcml0eSkge1xuICAgICAgICB2YXIgbmV3QXJnUG9zID0gYXJnUG9zID8gYXJyYXlDb3B5KGFyZ1BvcykgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBuZXdBcml0eSA9IG5hdGl2ZU1heChhcml0eSAtIGxlbmd0aCwgMCksXG4gICAgICAgICAgICBuZXdzSG9sZGVycyA9IGlzQ3VycnkgPyBhcmdzSG9sZGVycyA6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgIG5ld0hvbGRlcnNSaWdodCA9IGlzQ3VycnkgPyB1bmRlZmluZWQgOiBhcmdzSG9sZGVycyxcbiAgICAgICAgICAgIG5ld1BhcnRpYWxzID0gaXNDdXJyeSA/IGFyZ3MgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBuZXdQYXJ0aWFsc1JpZ2h0ID0gaXNDdXJyeSA/IHVuZGVmaW5lZCA6IGFyZ3M7XG5cbiAgICAgICAgYml0bWFzayB8PSAoaXNDdXJyeSA/IFBBUlRJQUxfRkxBRyA6IFBBUlRJQUxfUklHSFRfRkxBRyk7XG4gICAgICAgIGJpdG1hc2sgJj0gfihpc0N1cnJ5ID8gUEFSVElBTF9SSUdIVF9GTEFHIDogUEFSVElBTF9GTEFHKTtcblxuICAgICAgICBpZiAoIWlzQ3VycnlCb3VuZCkge1xuICAgICAgICAgIGJpdG1hc2sgJj0gfihCSU5EX0ZMQUcgfCBCSU5EX0tFWV9GTEFHKTtcbiAgICAgICAgfVxuICAgICAgICB2YXIgbmV3RGF0YSA9IFtmdW5jLCBiaXRtYXNrLCB0aGlzQXJnLCBuZXdQYXJ0aWFscywgbmV3c0hvbGRlcnMsIG5ld1BhcnRpYWxzUmlnaHQsIG5ld0hvbGRlcnNSaWdodCwgbmV3QXJnUG9zLCBhcnksIG5ld0FyaXR5XSxcbiAgICAgICAgICAgIHJlc3VsdCA9IGNyZWF0ZUh5YnJpZFdyYXBwZXIuYXBwbHkodW5kZWZpbmVkLCBuZXdEYXRhKTtcblxuICAgICAgICBpZiAoaXNMYXppYWJsZShmdW5jKSkge1xuICAgICAgICAgIHNldERhdGEocmVzdWx0LCBuZXdEYXRhKTtcbiAgICAgICAgfVxuICAgICAgICByZXN1bHQucGxhY2Vob2xkZXIgPSBwbGFjZWhvbGRlcjtcbiAgICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICAgIH1cbiAgICB9XG4gICAgdmFyIHRoaXNCaW5kaW5nID0gaXNCaW5kID8gdGhpc0FyZyA6IHRoaXMsXG4gICAgICAgIGZuID0gaXNCaW5kS2V5ID8gdGhpc0JpbmRpbmdbZnVuY10gOiBmdW5jO1xuXG4gICAgaWYgKGFyZ1Bvcykge1xuICAgICAgYXJncyA9IHJlb3JkZXIoYXJncywgYXJnUG9zKTtcbiAgICB9XG4gICAgaWYgKGlzQXJ5ICYmIGFyeSA8IGFyZ3MubGVuZ3RoKSB7XG4gICAgICBhcmdzLmxlbmd0aCA9IGFyeTtcbiAgICB9XG4gICAgaWYgKHRoaXMgJiYgdGhpcyAhPT0gZ2xvYmFsICYmIHRoaXMgaW5zdGFuY2VvZiB3cmFwcGVyKSB7XG4gICAgICBmbiA9IEN0b3IgfHwgY3JlYXRlQ3RvcldyYXBwZXIoZnVuYyk7XG4gICAgfVxuICAgIHJldHVybiBmbi5hcHBseSh0aGlzQmluZGluZywgYXJncyk7XG4gIH1cbiAgcmV0dXJuIHdyYXBwZXI7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gY3JlYXRlSHlicmlkV3JhcHBlcjtcbiJdfQ==","(function (global){\nvar createCtorWrapper = require('./createCtorWrapper');\n\n/** Used to compose bitmasks for wrapper metadata. */\nvar BIND_FLAG = 1;\n\n/**\n * Creates a function that wraps `func` and invokes it with the optional `this`\n * binding of `thisArg` and the `partials` prepended to those provided to\n * the wrapper.\n *\n * @private\n * @param {Function} func The function to partially apply arguments to.\n * @param {number} bitmask The bitmask of flags. See `createWrapper` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to the new function.\n * @returns {Function} Returns the new bound function.\n */\nfunction createPartialWrapper(func, bitmask, thisArg, partials) {\n  var isBind = bitmask & BIND_FLAG,\n      Ctor = createCtorWrapper(func);\n\n  function wrapper() {\n    // Avoid `arguments` object use disqualifying optimizations by\n    // converting it to an array before providing it `func`.\n    var argsIndex = -1,\n        argsLength = arguments.length,\n        leftIndex = -1,\n        leftLength = partials.length,\n        args = Array(leftLength + argsLength);\n\n    while (++leftIndex < leftLength) {\n      args[leftIndex] = partials[leftIndex];\n    }\n    while (argsLength--) {\n      args[leftIndex++] = arguments[++argsIndex];\n    }\n    var fn = (this && this !== global && this instanceof wrapper) ? Ctor : func;\n    return fn.apply(isBind ? thisArg : this, args);\n  }\n  return wrapper;\n}\n\nmodule.exports = createPartialWrapper;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2NyZWF0ZVBhcnRpYWxXcmFwcGVyLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgY3JlYXRlQ3RvcldyYXBwZXIgPSByZXF1aXJlKCcuL2NyZWF0ZUN0b3JXcmFwcGVyJyk7XG5cbi8qKiBVc2VkIHRvIGNvbXBvc2UgYml0bWFza3MgZm9yIHdyYXBwZXIgbWV0YWRhdGEuICovXG52YXIgQklORF9GTEFHID0gMTtcblxuLyoqXG4gKiBDcmVhdGVzIGEgZnVuY3Rpb24gdGhhdCB3cmFwcyBgZnVuY2AgYW5kIGludm9rZXMgaXQgd2l0aCB0aGUgb3B0aW9uYWwgYHRoaXNgXG4gKiBiaW5kaW5nIG9mIGB0aGlzQXJnYCBhbmQgdGhlIGBwYXJ0aWFsc2AgcHJlcGVuZGVkIHRvIHRob3NlIHByb3ZpZGVkIHRvXG4gKiB0aGUgd3JhcHBlci5cbiAqXG4gKiBAcHJpdmF0ZVxuICogQHBhcmFtIHtGdW5jdGlvbn0gZnVuYyBUaGUgZnVuY3Rpb24gdG8gcGFydGlhbGx5IGFwcGx5IGFyZ3VtZW50cyB0by5cbiAqIEBwYXJhbSB7bnVtYmVyfSBiaXRtYXNrIFRoZSBiaXRtYXNrIG9mIGZsYWdzLiBTZWUgYGNyZWF0ZVdyYXBwZXJgIGZvciBtb3JlIGRldGFpbHMuXG4gKiBAcGFyYW0geyp9IHRoaXNBcmcgVGhlIGB0aGlzYCBiaW5kaW5nIG9mIGBmdW5jYC5cbiAqIEBwYXJhbSB7QXJyYXl9IHBhcnRpYWxzIFRoZSBhcmd1bWVudHMgdG8gcHJlcGVuZCB0byB0aG9zZSBwcm92aWRlZCB0byB0aGUgbmV3IGZ1bmN0aW9uLlxuICogQHJldHVybnMge0Z1bmN0aW9ufSBSZXR1cm5zIHRoZSBuZXcgYm91bmQgZnVuY3Rpb24uXG4gKi9cbmZ1bmN0aW9uIGNyZWF0ZVBhcnRpYWxXcmFwcGVyKGZ1bmMsIGJpdG1hc2ssIHRoaXNBcmcsIHBhcnRpYWxzKSB7XG4gIHZhciBpc0JpbmQgPSBiaXRtYXNrICYgQklORF9GTEFHLFxuICAgICAgQ3RvciA9IGNyZWF0ZUN0b3JXcmFwcGVyKGZ1bmMpO1xuXG4gIGZ1bmN0aW9uIHdyYXBwZXIoKSB7XG4gICAgLy8gQXZvaWQgYGFyZ3VtZW50c2Agb2JqZWN0IHVzZSBkaXNxdWFsaWZ5aW5nIG9wdGltaXphdGlvbnMgYnlcbiAgICAvLyBjb252ZXJ0aW5nIGl0IHRvIGFuIGFycmF5IGJlZm9yZSBwcm92aWRpbmcgaXQgYGZ1bmNgLlxuICAgIHZhciBhcmdzSW5kZXggPSAtMSxcbiAgICAgICAgYXJnc0xlbmd0aCA9IGFyZ3VtZW50cy5sZW5ndGgsXG4gICAgICAgIGxlZnRJbmRleCA9IC0xLFxuICAgICAgICBsZWZ0TGVuZ3RoID0gcGFydGlhbHMubGVuZ3RoLFxuICAgICAgICBhcmdzID0gQXJyYXkobGVmdExlbmd0aCArIGFyZ3NMZW5ndGgpO1xuXG4gICAgd2hpbGUgKCsrbGVmdEluZGV4IDwgbGVmdExlbmd0aCkge1xuICAgICAgYXJnc1tsZWZ0SW5kZXhdID0gcGFydGlhbHNbbGVmdEluZGV4XTtcbiAgICB9XG4gICAgd2hpbGUgKGFyZ3NMZW5ndGgtLSkge1xuICAgICAgYXJnc1tsZWZ0SW5kZXgrK10gPSBhcmd1bWVudHNbKythcmdzSW5kZXhdO1xuICAgIH1cbiAgICB2YXIgZm4gPSAodGhpcyAmJiB0aGlzICE9PSBnbG9iYWwgJiYgdGhpcyBpbnN0YW5jZW9mIHdyYXBwZXIpID8gQ3RvciA6IGZ1bmM7XG4gICAgcmV0dXJuIGZuLmFwcGx5KGlzQmluZCA/IHRoaXNBcmcgOiB0aGlzLCBhcmdzKTtcbiAgfVxuICByZXR1cm4gd3JhcHBlcjtcbn1cblxubW9kdWxlLmV4cG9ydHMgPSBjcmVhdGVQYXJ0aWFsV3JhcHBlcjtcbiJdfQ==","var baseSetData = require('./baseSetData'),\n    createBindWrapper = require('./createBindWrapper'),\n    createHybridWrapper = require('./createHybridWrapper'),\n    createPartialWrapper = require('./createPartialWrapper'),\n    getData = require('./getData'),\n    mergeData = require('./mergeData'),\n    setData = require('./setData');\n\n/** Used to compose bitmasks for wrapper metadata. */\nvar BIND_FLAG = 1,\n    BIND_KEY_FLAG = 2,\n    PARTIAL_FLAG = 32,\n    PARTIAL_RIGHT_FLAG = 64;\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to reference.\n * @param {number} bitmask The bitmask of flags.\n *  The bitmask may be composed of the following flags:\n *     1 - `_.bind`\n *     2 - `_.bindKey`\n *     4 - `_.curry` or `_.curryRight` of a bound function\n *     8 - `_.curry`\n *    16 - `_.curryRight`\n *    32 - `_.partial`\n *    64 - `_.partialRight`\n *   128 - `_.rearg`\n *   256 - `_.ary`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createWrapper(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n  var isBindKey = bitmask & BIND_KEY_FLAG;\n  if (!isBindKey && typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  var length = partials ? partials.length : 0;\n  if (!length) {\n    bitmask &= ~(PARTIAL_FLAG | PARTIAL_RIGHT_FLAG);\n    partials = holders = undefined;\n  }\n  length -= (holders ? holders.length : 0);\n  if (bitmask & PARTIAL_RIGHT_FLAG) {\n    var partialsRight = partials,\n        holdersRight = holders;\n\n    partials = holders = undefined;\n  }\n  var data = isBindKey ? undefined : getData(func),\n      newData = [func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity];\n\n  if (data) {\n    mergeData(newData, data);\n    bitmask = newData[1];\n    arity = newData[9];\n  }\n  newData[9] = arity == null\n    ? (isBindKey ? 0 : func.length)\n    : (nativeMax(arity - length, 0) || 0);\n\n  if (bitmask == BIND_FLAG) {\n    var result = createBindWrapper(newData[0], newData[2]);\n  } else if ((bitmask == PARTIAL_FLAG || bitmask == (BIND_FLAG | PARTIAL_FLAG)) && !newData[4].length) {\n    result = createPartialWrapper.apply(undefined, newData);\n  } else {\n    result = createHybridWrapper.apply(undefined, newData);\n  }\n  var setter = data ? baseSetData : setData;\n  return setter(result, newData);\n}\n\nmodule.exports = createWrapper;\n","var arraySome = require('./arraySome');\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} [customizer] The function to customize comparing arrays.\n * @param {boolean} [isLoose] Specify performing partial comparisons.\n * @param {Array} [stackA] Tracks traversed `value` objects.\n * @param {Array} [stackB] Tracks traversed `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, equalFunc, customizer, isLoose, stackA, stackB) {\n  var index = -1,\n      arrLength = array.length,\n      othLength = other.length;\n\n  if (arrLength != othLength && !(isLoose && othLength > arrLength)) {\n    return false;\n  }\n  // Ignore non-index properties.\n  while (++index < arrLength) {\n    var arrValue = array[index],\n        othValue = other[index],\n        result = customizer ? customizer(isLoose ? othValue : arrValue, isLoose ? arrValue : othValue, index) : undefined;\n\n    if (result !== undefined) {\n      if (result) {\n        continue;\n      }\n      return false;\n    }\n    // Recursively compare arrays (susceptible to call stack limits).\n    if (isLoose) {\n      if (!arraySome(other, function(othValue) {\n            return arrValue === othValue || equalFunc(arrValue, othValue, customizer, isLoose, stackA, stackB);\n          })) {\n        return false;\n      }\n    } else if (!(arrValue === othValue || equalFunc(arrValue, othValue, customizer, isLoose, stackA, stackB))) {\n      return false;\n    }\n  }\n  return true;\n}\n\nmodule.exports = equalArrays;\n","/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    stringTag = '[object String]';\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag) {\n  switch (tag) {\n    case boolTag:\n    case dateTag:\n      // Coerce dates and booleans to numbers, dates to milliseconds and booleans\n      // to `1` or `0` treating invalid dates coerced to `NaN` as not equal.\n      return +object == +other;\n\n    case errorTag:\n      return object.name == other.name && object.message == other.message;\n\n    case numberTag:\n      // Treat `NaN` vs. `NaN` as equal.\n      return (object != +object)\n        ? other != +other\n        : object == +other;\n\n    case regexpTag:\n    case stringTag:\n      // Coerce regexes to strings and treat strings primitives and string\n      // objects as equal. See https://es5.github.io/#x15.10.6.4 for more details.\n      return object == (other + '');\n  }\n  return false;\n}\n\nmodule.exports = equalByTag;\n","var keys = require('../object/keys');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Function} [customizer] The function to customize comparing values.\n * @param {boolean} [isLoose] Specify performing partial comparisons.\n * @param {Array} [stackA] Tracks traversed `value` objects.\n * @param {Array} [stackB] Tracks traversed `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, equalFunc, customizer, isLoose, stackA, stackB) {\n  var objProps = keys(object),\n      objLength = objProps.length,\n      othProps = keys(other),\n      othLength = othProps.length;\n\n  if (objLength != othLength && !isLoose) {\n    return false;\n  }\n  var index = objLength;\n  while (index--) {\n    var key = objProps[index];\n    if (!(isLoose ? key in other : hasOwnProperty.call(other, key))) {\n      return false;\n    }\n  }\n  var skipCtor = isLoose;\n  while (++index < objLength) {\n    key = objProps[index];\n    var objValue = object[key],\n        othValue = other[key],\n        result = customizer ? customizer(isLoose ? othValue : objValue, isLoose? objValue : othValue, key) : undefined;\n\n    // Recursively compare objects (susceptible to call stack limits).\n    if (!(result === undefined ? equalFunc(objValue, othValue, customizer, isLoose, stackA, stackB) : result)) {\n      return false;\n    }\n    skipCtor || (skipCtor = key == 'constructor');\n  }\n  if (!skipCtor) {\n    var objCtor = object.constructor,\n        othCtor = other.constructor;\n\n    // Non `Object` object instances with different constructors are not equal.\n    if (objCtor != othCtor &&\n        ('constructor' in object && 'constructor' in other) &&\n        !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n          typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nmodule.exports = equalObjects;\n","var metaMap = require('./metaMap'),\n    noop = require('../utility/noop');\n\n/**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\nvar getData = !metaMap ? noop : function(func) {\n  return metaMap.get(func);\n};\n\nmodule.exports = getData;\n","var realNames = require('./realNames');\n\n/**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\nfunction getFuncName(func) {\n  var result = (func.name + ''),\n      array = realNames[result],\n      length = array ? array.length : 0;\n\n  while (length--) {\n    var data = array[length],\n        otherFunc = data.func;\n    if (otherFunc == null || otherFunc == func) {\n      return data.name;\n    }\n  }\n  return result;\n}\n\nmodule.exports = getFuncName;\n","var baseProperty = require('./baseProperty');\n\n/**\n * Gets the \"length\" property value of `object`.\n *\n * **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792)\n * that affects Safari on at least iOS 8.1-8.3 ARM64.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {*} Returns the \"length\" value.\n */\nvar getLength = baseProperty('length');\n\nmodule.exports = getLength;\n","var isStrictComparable = require('./isStrictComparable'),\n    pairs = require('../object/pairs');\n\n/**\n * Gets the propery names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n  var result = pairs(object),\n      length = result.length;\n\n  while (length--) {\n    result[length][2] = isStrictComparable(result[length][1]);\n  }\n  return result;\n}\n\nmodule.exports = getMatchData;\n","var isNative = require('../lang/isNative');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n  var value = object == null ? undefined : object[key];\n  return isNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","/**\n * Gets the index at which the first occurrence of `NaN` is found in `array`.\n *\n * @private\n * @param {Array} array The array to search.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched `NaN`, else `-1`.\n */\nfunction indexOfNaN(array, fromIndex, fromRight) {\n  var length = array.length,\n      index = fromIndex + (fromRight ? 0 : -1);\n\n  while ((fromRight ? index-- : ++index < length)) {\n    var other = array[index];\n    if (other !== other) {\n      return index;\n    }\n  }\n  return -1;\n}\n\nmodule.exports = indexOfNaN;\n","/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n  var length = array.length,\n      result = new array.constructor(length);\n\n  // Add array properties assigned by `RegExp#exec`.\n  if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n    result.index = array.index;\n    result.input = array.input;\n  }\n  return result;\n}\n\nmodule.exports = initCloneArray;\n","(function (global){\nvar bufferClone = require('./bufferClone');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    numberTag = '[object Number]',\n    regexpTag = '[object RegExp]',\n    stringTag = '[object String]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/** Native method references. */\nvar Uint8Array = global.Uint8Array;\n\n/** Used to lookup a type array constructors by `toStringTag`. */\nvar ctorByTag = {};\nctorByTag[float32Tag] = global.Float32Array;\nctorByTag[float64Tag] = global.Float64Array;\nctorByTag[int8Tag] = global.Int8Array;\nctorByTag[int16Tag] = global.Int16Array;\nctorByTag[int32Tag] = global.Int32Array;\nctorByTag[uint8Tag] = Uint8Array;\nctorByTag[uint8ClampedTag] = global.Uint8ClampedArray;\nctorByTag[uint16Tag] = global.Uint16Array;\nctorByTag[uint32Tag] = global.Uint32Array;\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n  var Ctor = object.constructor;\n  switch (tag) {\n    case arrayBufferTag:\n      return bufferClone(object);\n\n    case boolTag:\n    case dateTag:\n      return new Ctor(+object);\n\n    case float32Tag: case float64Tag:\n    case int8Tag: case int16Tag: case int32Tag:\n    case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n      // Safari 5 mobile incorrectly has `Object` as the constructor of typed arrays.\n      if (Ctor instanceof Ctor) {\n        Ctor = ctorByTag[tag];\n      }\n      var buffer = object.buffer;\n      return new Ctor(isDeep ? bufferClone(buffer) : buffer, object.byteOffset, object.length);\n\n    case numberTag:\n    case stringTag:\n      return new Ctor(object);\n\n    case regexpTag:\n      var result = new Ctor(object.source, reFlags.exec(object));\n      result.lastIndex = object.lastIndex;\n  }\n  return result;\n}\n\nmodule.exports = initCloneByTag;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL2luaXRDbG9uZUJ5VGFnLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgYnVmZmVyQ2xvbmUgPSByZXF1aXJlKCcuL2J1ZmZlckNsb25lJyk7XG5cbi8qKiBgT2JqZWN0I3RvU3RyaW5nYCByZXN1bHQgcmVmZXJlbmNlcy4gKi9cbnZhciBib29sVGFnID0gJ1tvYmplY3QgQm9vbGVhbl0nLFxuICAgIGRhdGVUYWcgPSAnW29iamVjdCBEYXRlXScsXG4gICAgbnVtYmVyVGFnID0gJ1tvYmplY3QgTnVtYmVyXScsXG4gICAgcmVnZXhwVGFnID0gJ1tvYmplY3QgUmVnRXhwXScsXG4gICAgc3RyaW5nVGFnID0gJ1tvYmplY3QgU3RyaW5nXSc7XG5cbnZhciBhcnJheUJ1ZmZlclRhZyA9ICdbb2JqZWN0IEFycmF5QnVmZmVyXScsXG4gICAgZmxvYXQzMlRhZyA9ICdbb2JqZWN0IEZsb2F0MzJBcnJheV0nLFxuICAgIGZsb2F0NjRUYWcgPSAnW29iamVjdCBGbG9hdDY0QXJyYXldJyxcbiAgICBpbnQ4VGFnID0gJ1tvYmplY3QgSW50OEFycmF5XScsXG4gICAgaW50MTZUYWcgPSAnW29iamVjdCBJbnQxNkFycmF5XScsXG4gICAgaW50MzJUYWcgPSAnW29iamVjdCBJbnQzMkFycmF5XScsXG4gICAgdWludDhUYWcgPSAnW29iamVjdCBVaW50OEFycmF5XScsXG4gICAgdWludDhDbGFtcGVkVGFnID0gJ1tvYmplY3QgVWludDhDbGFtcGVkQXJyYXldJyxcbiAgICB1aW50MTZUYWcgPSAnW29iamVjdCBVaW50MTZBcnJheV0nLFxuICAgIHVpbnQzMlRhZyA9ICdbb2JqZWN0IFVpbnQzMkFycmF5XSc7XG5cbi8qKiBVc2VkIHRvIG1hdGNoIGBSZWdFeHBgIGZsYWdzIGZyb20gdGhlaXIgY29lcmNlZCBzdHJpbmcgdmFsdWVzLiAqL1xudmFyIHJlRmxhZ3MgPSAvXFx3KiQvO1xuXG4vKiogTmF0aXZlIG1ldGhvZCByZWZlcmVuY2VzLiAqL1xudmFyIFVpbnQ4QXJyYXkgPSBnbG9iYWwuVWludDhBcnJheTtcblxuLyoqIFVzZWQgdG8gbG9va3VwIGEgdHlwZSBhcnJheSBjb25zdHJ1Y3RvcnMgYnkgYHRvU3RyaW5nVGFnYC4gKi9cbnZhciBjdG9yQnlUYWcgPSB7fTtcbmN0b3JCeVRhZ1tmbG9hdDMyVGFnXSA9IGdsb2JhbC5GbG9hdDMyQXJyYXk7XG5jdG9yQnlUYWdbZmxvYXQ2NFRhZ10gPSBnbG9iYWwuRmxvYXQ2NEFycmF5O1xuY3RvckJ5VGFnW2ludDhUYWddID0gZ2xvYmFsLkludDhBcnJheTtcbmN0b3JCeVRhZ1tpbnQxNlRhZ10gPSBnbG9iYWwuSW50MTZBcnJheTtcbmN0b3JCeVRhZ1tpbnQzMlRhZ10gPSBnbG9iYWwuSW50MzJBcnJheTtcbmN0b3JCeVRhZ1t1aW50OFRhZ10gPSBVaW50OEFycmF5O1xuY3RvckJ5VGFnW3VpbnQ4Q2xhbXBlZFRhZ10gPSBnbG9iYWwuVWludDhDbGFtcGVkQXJyYXk7XG5jdG9yQnlUYWdbdWludDE2VGFnXSA9IGdsb2JhbC5VaW50MTZBcnJheTtcbmN0b3JCeVRhZ1t1aW50MzJUYWddID0gZ2xvYmFsLlVpbnQzMkFycmF5O1xuXG4vKipcbiAqIEluaXRpYWxpemVzIGFuIG9iamVjdCBjbG9uZSBiYXNlZCBvbiBpdHMgYHRvU3RyaW5nVGFnYC5cbiAqXG4gKiAqKk5vdGU6KiogVGhpcyBmdW5jdGlvbiBvbmx5IHN1cHBvcnRzIGNsb25pbmcgdmFsdWVzIHdpdGggdGFncyBvZlxuICogYEJvb2xlYW5gLCBgRGF0ZWAsIGBFcnJvcmAsIGBOdW1iZXJgLCBgUmVnRXhwYCwgb3IgYFN0cmluZ2AuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7T2JqZWN0fSBvYmplY3QgVGhlIG9iamVjdCB0byBjbG9uZS5cbiAqIEBwYXJhbSB7c3RyaW5nfSB0YWcgVGhlIGB0b1N0cmluZ1RhZ2Agb2YgdGhlIG9iamVjdCB0byBjbG9uZS5cbiAqIEBwYXJhbSB7Ym9vbGVhbn0gW2lzRGVlcF0gU3BlY2lmeSBhIGRlZXAgY2xvbmUuXG4gKiBAcmV0dXJucyB7T2JqZWN0fSBSZXR1cm5zIHRoZSBpbml0aWFsaXplZCBjbG9uZS5cbiAqL1xuZnVuY3Rpb24gaW5pdENsb25lQnlUYWcob2JqZWN0LCB0YWcsIGlzRGVlcCkge1xuICB2YXIgQ3RvciA9IG9iamVjdC5jb25zdHJ1Y3RvcjtcbiAgc3dpdGNoICh0YWcpIHtcbiAgICBjYXNlIGFycmF5QnVmZmVyVGFnOlxuICAgICAgcmV0dXJuIGJ1ZmZlckNsb25lKG9iamVjdCk7XG5cbiAgICBjYXNlIGJvb2xUYWc6XG4gICAgY2FzZSBkYXRlVGFnOlxuICAgICAgcmV0dXJuIG5ldyBDdG9yKCtvYmplY3QpO1xuXG4gICAgY2FzZSBmbG9hdDMyVGFnOiBjYXNlIGZsb2F0NjRUYWc6XG4gICAgY2FzZSBpbnQ4VGFnOiBjYXNlIGludDE2VGFnOiBjYXNlIGludDMyVGFnOlxuICAgIGNhc2UgdWludDhUYWc6IGNhc2UgdWludDhDbGFtcGVkVGFnOiBjYXNlIHVpbnQxNlRhZzogY2FzZSB1aW50MzJUYWc6XG4gICAgICAvLyBTYWZhcmkgNSBtb2JpbGUgaW5jb3JyZWN0bHkgaGFzIGBPYmplY3RgIGFzIHRoZSBjb25zdHJ1Y3RvciBvZiB0eXBlZCBhcnJheXMuXG4gICAgICBpZiAoQ3RvciBpbnN0YW5jZW9mIEN0b3IpIHtcbiAgICAgICAgQ3RvciA9IGN0b3JCeVRhZ1t0YWddO1xuICAgICAgfVxuICAgICAgdmFyIGJ1ZmZlciA9IG9iamVjdC5idWZmZXI7XG4gICAgICByZXR1cm4gbmV3IEN0b3IoaXNEZWVwID8gYnVmZmVyQ2xvbmUoYnVmZmVyKSA6IGJ1ZmZlciwgb2JqZWN0LmJ5dGVPZmZzZXQsIG9iamVjdC5sZW5ndGgpO1xuXG4gICAgY2FzZSBudW1iZXJUYWc6XG4gICAgY2FzZSBzdHJpbmdUYWc6XG4gICAgICByZXR1cm4gbmV3IEN0b3Iob2JqZWN0KTtcblxuICAgIGNhc2UgcmVnZXhwVGFnOlxuICAgICAgdmFyIHJlc3VsdCA9IG5ldyBDdG9yKG9iamVjdC5zb3VyY2UsIHJlRmxhZ3MuZXhlYyhvYmplY3QpKTtcbiAgICAgIHJlc3VsdC5sYXN0SW5kZXggPSBvYmplY3QubGFzdEluZGV4O1xuICB9XG4gIHJldHVybiByZXN1bHQ7XG59XG5cbm1vZHVsZS5leHBvcnRzID0gaW5pdENsb25lQnlUYWc7XG4iXX0=","/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n  var Ctor = object.constructor;\n  if (!(typeof Ctor == 'function' && Ctor instanceof Ctor)) {\n    Ctor = Object;\n  }\n  return new Ctor;\n}\n\nmodule.exports = initCloneObject;\n","var getLength = require('./getLength'),\n    isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(getLength(value));\n}\n\nmodule.exports = isArrayLike;\n","/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nvar isHostObject = (function() {\n  try {\n    Object({ 'toString': 0 } + '');\n  } catch(e) {\n    return function() { return false; };\n  }\n  return function(value) {\n    // IE < 9 presents many host objects as `Object` objects that can coerce\n    // to strings despite having improperly defined `toString` methods.\n    return typeof value.toString != 'function' && typeof (value + '') == 'string';\n  };\n}());\n\nmodule.exports = isHostObject;\n","/** Used to detect unsigned integer values. */\nvar reIsUint = /^\\d+$/;\n\n/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1;\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return value > -1 && value % 1 == 0 && value < length;\n}\n\nmodule.exports = isIndex;\n","var isArrayLike = require('./isArrayLike'),\n    isIndex = require('./isIndex'),\n    isObject = require('../lang/isObject');\n\n/**\n * Checks if the provided arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call, else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n  if (!isObject(object)) {\n    return false;\n  }\n  var type = typeof index;\n  if (type == 'number'\n      ? (isArrayLike(object) && isIndex(index, object.length))\n      : (type == 'string' && index in object)) {\n    var other = object[index];\n    return value === value ? (value === other) : (other !== other);\n  }\n  return false;\n}\n\nmodule.exports = isIterateeCall;\n","var isArray = require('../lang/isArray'),\n    toObject = require('./toObject');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\n\\\\]|\\\\.)*?\\1)\\]/,\n    reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n  var type = typeof value;\n  if ((type == 'string' && reIsPlainProp.test(value)) || type == 'number') {\n    return true;\n  }\n  if (isArray(value)) {\n    return false;\n  }\n  var result = !reIsDeepProp.test(value);\n  return result || (object != null && value in toObject(object));\n}\n\nmodule.exports = isKey;\n","var LazyWrapper = require('./LazyWrapper'),\n    getData = require('./getData'),\n    getFuncName = require('./getFuncName'),\n    lodash = require('../chain/lodash');\n\n/**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart, else `false`.\n */\nfunction isLaziable(func) {\n  var funcName = getFuncName(func),\n      other = lodash[funcName];\n\n  if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n    return false;\n  }\n  if (func === other) {\n    return true;\n  }\n  var data = getData(other);\n  return !!data && func === data[0];\n}\n\nmodule.exports = isLaziable;\n","/**\n * Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer)\n * of an array-like value.\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength).\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n */\nfunction isLength(value) {\n  return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","/**\n * Checks if `value` is object-like.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var isObject = require('../lang/isObject');\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n *  equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n  return value === value && !isObject(value);\n}\n\nmodule.exports = isStrictComparable;\n","var arrayCopy = require('./arrayCopy'),\n    composeArgs = require('./composeArgs'),\n    composeArgsRight = require('./composeArgsRight'),\n    replaceHolders = require('./replaceHolders');\n\n/** Used to compose bitmasks for wrapper metadata. */\nvar BIND_FLAG = 1,\n    CURRY_BOUND_FLAG = 4,\n    CURRY_FLAG = 8,\n    ARY_FLAG = 128,\n    REARG_FLAG = 256;\n\n/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers required to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and `_.rearg`\n * augment function arguments, making the order in which they are executed important,\n * preventing the merging of metadata. However, we make an exception for a safe\n * common case where curried functions have `_.ary` and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\nfunction mergeData(data, source) {\n  var bitmask = data[1],\n      srcBitmask = source[1],\n      newBitmask = bitmask | srcBitmask,\n      isCommon = newBitmask < ARY_FLAG;\n\n  var isCombo =\n    (srcBitmask == ARY_FLAG && bitmask == CURRY_FLAG) ||\n    (srcBitmask == ARY_FLAG && bitmask == REARG_FLAG && data[7].length <= source[8]) ||\n    (srcBitmask == (ARY_FLAG | REARG_FLAG) && bitmask == CURRY_FLAG);\n\n  // Exit early if metadata can't be merged.\n  if (!(isCommon || isCombo)) {\n    return data;\n  }\n  // Use source `thisArg` if available.\n  if (srcBitmask & BIND_FLAG) {\n    data[2] = source[2];\n    // Set when currying a bound function.\n    newBitmask |= (bitmask & BIND_FLAG) ? 0 : CURRY_BOUND_FLAG;\n  }\n  // Compose partial arguments.\n  var value = source[3];\n  if (value) {\n    var partials = data[3];\n    data[3] = partials ? composeArgs(partials, value, source[4]) : arrayCopy(value);\n    data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : arrayCopy(source[4]);\n  }\n  // Compose partial right arguments.\n  value = source[5];\n  if (value) {\n    partials = data[5];\n    data[5] = partials ? composeArgsRight(partials, value, source[6]) : arrayCopy(value);\n    data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : arrayCopy(source[6]);\n  }\n  // Use source `argPos` if available.\n  value = source[7];\n  if (value) {\n    data[7] = arrayCopy(value);\n  }\n  // Use source `ary` if it's smaller.\n  if (srcBitmask & ARY_FLAG) {\n    data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n  }\n  // Use source `arity` if one is not provided.\n  if (data[9] == null) {\n    data[9] = source[9];\n  }\n  // Use source `func` and merge bitmasks.\n  data[0] = source[0];\n  data[1] = newBitmask;\n\n  return data;\n}\n\nmodule.exports = mergeData;\n","(function (global){\nvar getNative = require('./getNative');\n\n/** Native method references. */\nvar WeakMap = getNative(global, 'WeakMap');\n\n/** Used to store function metadata. */\nvar metaMap = WeakMap && new WeakMap;\n\nmodule.exports = metaMap;\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIm5vZGVfbW9kdWxlcy9sb2Rhc2gtY29tcGF0L2ludGVybmFsL21ldGFNYXAuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6ImdlbmVyYXRlZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgZ2V0TmF0aXZlID0gcmVxdWlyZSgnLi9nZXROYXRpdmUnKTtcblxuLyoqIE5hdGl2ZSBtZXRob2QgcmVmZXJlbmNlcy4gKi9cbnZhciBXZWFrTWFwID0gZ2V0TmF0aXZlKGdsb2JhbCwgJ1dlYWtNYXAnKTtcblxuLyoqIFVzZWQgdG8gc3RvcmUgZnVuY3Rpb24gbWV0YWRhdGEuICovXG52YXIgbWV0YU1hcCA9IFdlYWtNYXAgJiYgbmV3IFdlYWtNYXA7XG5cbm1vZHVsZS5leHBvcnRzID0gbWV0YU1hcDtcbiJdfQ==","/** Used to lookup unminified function names. */\nvar realNames = {};\n\nmodule.exports = realNames;\n","var arrayCopy = require('./arrayCopy'),\n    isIndex = require('./isIndex');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\nfunction reorder(array, indexes) {\n  var arrLength = array.length,\n      length = nativeMin(indexes.length, arrLength),\n      oldArray = arrayCopy(array);\n\n  while (length--) {\n    var index = indexes[length];\n    array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n  }\n  return array;\n}\n\nmodule.exports = reorder;\n","/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\nfunction replaceHolders(array, placeholder) {\n  var index = -1,\n      length = array.length,\n      resIndex = -1,\n      result = [];\n\n  while (++index < length) {\n    if (array[index] === placeholder) {\n      array[index] = PLACEHOLDER;\n      result[++resIndex] = index;\n    }\n  }\n  return result;\n}\n\nmodule.exports = replaceHolders;\n","var baseSetData = require('./baseSetData'),\n    now = require('../date/now');\n\n/** Used to detect when a function becomes hot. */\nvar HOT_COUNT = 150,\n    HOT_SPAN = 16;\n\n/**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity function\n * to avoid garbage collection pauses in V8. See [V8 issue 2070](https://code.google.com/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar setData = (function() {\n  var count = 0,\n      lastCalled = 0;\n\n  return function(key, value) {\n    var stamp = now(),\n        remaining = HOT_SPAN - (stamp - lastCalled);\n\n    lastCalled = stamp;\n    if (remaining > 0) {\n      if (++count >= HOT_COUNT) {\n        return key;\n      }\n    } else {\n      count = 0;\n    }\n    return baseSetData(key, value);\n  };\n}());\n\nmodule.exports = setData;\n","var isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isIndex = require('./isIndex'),\n    isLength = require('./isLength'),\n    isString = require('../lang/isString'),\n    keysIn = require('../object/keysIn');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * A fallback implementation of `Object.keys` which creates an array of the\n * own enumerable property names of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction shimKeys(object) {\n  var props = keysIn(object),\n      propsLength = props.length,\n      length = propsLength && object.length;\n\n  var allowIndexes = !!length && isLength(length) &&\n    (isArray(object) || isArguments(object) || isString(object));\n\n  var index = -1,\n      result = [];\n\n  while (++index < propsLength) {\n    var key = props[index];\n    if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\nmodule.exports = shimKeys;\n","var isObject = require('../lang/isObject'),\n    isString = require('../lang/isString'),\n    support = require('../support');\n\n/**\n * Converts `value` to an object if it's not one.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {Object} Returns the object.\n */\nfunction toObject(value) {\n  if (support.unindexedChars && isString(value)) {\n    var index = -1,\n        length = value.length,\n        result = Object(value);\n\n    while (++index < length) {\n      result[index] = value.charAt(index);\n    }\n    return result;\n  }\n  return isObject(value) ? value : Object(value);\n}\n\nmodule.exports = toObject;\n","var baseToString = require('./baseToString'),\n    isArray = require('../lang/isArray');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\n\\\\]|\\\\.)*?)\\2)\\]/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `value` to property path array if it's not one.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {Array} Returns the property path array.\n */\nfunction toPath(value) {\n  if (isArray(value)) {\n    return value;\n  }\n  var result = [];\n  baseToString(value).replace(rePropName, function(match, number, quote, string) {\n    result.push(quote ? string.replace(reEscapeChar, '$1') : (number || match));\n  });\n  return result;\n}\n\nmodule.exports = toPath;\n","var LazyWrapper = require('./LazyWrapper'),\n    LodashWrapper = require('./LodashWrapper'),\n    arrayCopy = require('./arrayCopy');\n\n/**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\nfunction wrapperClone(wrapper) {\n  return wrapper instanceof LazyWrapper\n    ? wrapper.clone()\n    : new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__, arrayCopy(wrapper.__actions__));\n}\n\nmodule.exports = wrapperClone;\n","var baseClone = require('../internal/baseClone'),\n    bindCallback = require('../internal/bindCallback');\n\n/**\n * Creates a deep clone of `value`. If `customizer` is provided it's invoked\n * to produce the cloned values. If `customizer` returns `undefined` cloning\n * is handled by the method instead. The `customizer` is bound to `thisArg`\n * and invoked with up to three argument; (value [, index|key, object]).\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](http://www.w3.org/TR/html5/infrastructure.html#internal-structured-cloning-algorithm).\n * The enumerable properties of `arguments` objects and objects created by\n * constructors other than `Object` are cloned to plain `Object` objects. An\n * empty object is returned for uncloneable values such as functions, DOM nodes,\n * Maps, Sets, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to deep clone.\n * @param {Function} [customizer] The function to customize cloning values.\n * @param {*} [thisArg] The `this` binding of `customizer`.\n * @returns {*} Returns the deep cloned value.\n * @example\n *\n * var users = [\n *   { 'user': 'barney' },\n *   { 'user': 'fred' }\n * ];\n *\n * var deep = _.cloneDeep(users);\n * deep[0] === users[0];\n * // => false\n *\n * // using a customizer callback\n * var el = _.cloneDeep(document.body, function(value) {\n *   if (_.isElement(value)) {\n *     return value.cloneNode(true);\n *   }\n * });\n *\n * el === document.body\n * // => false\n * el.nodeName\n * // => BODY\n * el.childNodes.length;\n * // => 20\n */\nfunction cloneDeep(value, customizer, thisArg) {\n  return typeof customizer == 'function'\n    ? baseClone(value, true, bindCallback(customizer, thisArg, 3))\n    : baseClone(value, true);\n}\n\nmodule.exports = cloneDeep;\n","var isArrayLike = require('../internal/isArrayLike'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Native method references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is classified as an `arguments` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  return isObjectLike(value) && isArrayLike(value) &&\n    hasOwnProperty.call(value, 'callee') && !propertyIsEnumerable.call(value, 'callee');\n}\n\nmodule.exports = isArguments;\n","var getNative = require('../internal/getNative'),\n    isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar arrayTag = '[object Array]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeIsArray = getNative(Array, 'isArray');\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(function() { return arguments; }());\n * // => false\n */\nvar isArray = nativeIsArray || function(value) {\n  return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag;\n};\n\nmodule.exports = isArray;\n","var isArguments = require('./isArguments'),\n    isArray = require('./isArray'),\n    isArrayLike = require('../internal/isArrayLike'),\n    isFunction = require('./isFunction'),\n    isObjectLike = require('../internal/isObjectLike'),\n    isString = require('./isString'),\n    keys = require('../object/keys');\n\n/**\n * Checks if `value` is empty. A value is considered empty unless it's an\n * `arguments` object, array, string, or jQuery-like collection with a length\n * greater than `0` or an object with own enumerable properties.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {Array|Object|string} value The value to inspect.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n  if (value == null) {\n    return true;\n  }\n  if (isArrayLike(value) && (isArray(value) || isString(value) || isArguments(value) ||\n      (isObjectLike(value) && isFunction(value.splice)))) {\n    return !value.length;\n  }\n  return !keys(value).length;\n}\n\nmodule.exports = isEmpty;\n","var isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in older versions of Chrome and Safari which return 'function' for regexes\n  // and Safari 8 which returns 'object' for typed array constructors.\n  return isObject(value) && objToString.call(value) == funcTag;\n}\n\nmodule.exports = isFunction;\n","var isFunction = require('./isFunction'),\n    isHostObject = require('../internal/isHostObject'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** Used to detect host constructors (Safari > 5). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar fnToString = Function.prototype.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n  fnToString.call(hasOwnProperty).replace(/[\\\\^$.*+?()[\\]{}|]/g, '\\\\$&')\n  .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * Checks if `value` is a native function.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function, else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\nfunction isNative(value) {\n  if (value == null) {\n    return false;\n  }\n  if (isFunction(value)) {\n    return reIsNative.test(fnToString.call(value));\n  }\n  return isObjectLike(value) && (isHostObject(value) ? reIsNative : reIsHostCtor).test(value);\n}\n\nmodule.exports = isNative;\n","/**\n * Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`.\n * (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(1);\n * // => false\n */\nfunction isObject(value) {\n  // Avoid a V8 JIT bug in Chrome 19-20.\n  // See https://code.google.com/p/v8/issues/detail?id=2291 for more details.\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","var baseForIn = require('../internal/baseForIn'),\n    isArguments = require('./isArguments'),\n    isHostObject = require('../internal/isHostObject'),\n    isObjectLike = require('../internal/isObjectLike'),\n    support = require('../support');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * **Note:** This method assumes objects created by the `Object` constructor\n * have no inherited enumerable properties.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  var Ctor;\n\n  // Exit early for non `Object` objects.\n  if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isHostObject(value) && !isArguments(value)) ||\n      (!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) {\n    return false;\n  }\n  // IE < 9 iterates inherited properties before own properties. If the first\n  // iterated property is an object's own property then there are no inherited\n  // enumerable properties.\n  var result;\n  if (support.ownLast) {\n    baseForIn(value, function(subValue, key, object) {\n      result = hasOwnProperty.call(object, key);\n      return false;\n    });\n    return result !== false;\n  }\n  // In most environments an object's own properties are iterated before\n  // its inherited properties. If the last iterated property is an object's\n  // own property then there are no inherited enumerable properties.\n  baseForIn(value, function(subValue, key) {\n    result = key;\n  });\n  return result === undefined || hasOwnProperty.call(value, result);\n}\n\nmodule.exports = isPlainObject;\n","var isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' || (isObjectLike(value) && objToString.call(value) == stringTag);\n}\n\nmodule.exports = isString;\n","var isLength = require('../internal/isLength'),\n    isObjectLike = require('../internal/isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    mapTag = '[object Map]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    setTag = '[object Set]',\n    stringTag = '[object String]',\n    weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n    float32Tag = '[object Float32Array]',\n    float64Tag = '[object Float64Array]',\n    int8Tag = '[object Int8Array]',\n    int16Tag = '[object Int16Array]',\n    int32Tag = '[object Int32Array]',\n    uint8Tag = '[object Uint8Array]',\n    uint8ClampedTag = '[object Uint8ClampedArray]',\n    uint16Tag = '[object Uint16Array]',\n    uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dateTag] = typedArrayTags[errorTag] =\ntypedArrayTags[funcTag] = typedArrayTags[mapTag] =\ntypedArrayTags[numberTag] = typedArrayTags[objectTag] =\ntypedArrayTags[regexpTag] = typedArrayTags[setTag] =\ntypedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false;\n\n/** Used for native method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nfunction isTypedArray(value) {\n  return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objToString.call(value)];\n}\n\nmodule.exports = isTypedArray;\n","/**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\nfunction isUndefined(value) {\n  return value === undefined;\n}\n\nmodule.exports = isUndefined;\n","var getNative = require('../internal/getNative'),\n    isArrayLike = require('../internal/isArrayLike'),\n    isObject = require('../lang/isObject'),\n    shimKeys = require('../internal/shimKeys'),\n    support = require('../support');\n\n/* Native method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = getNative(Object, 'keys');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nvar keys = !nativeKeys ? shimKeys : function(object) {\n  var Ctor = object == null ? undefined : object.constructor;\n  if ((typeof Ctor == 'function' && Ctor.prototype === object) ||\n      (typeof object == 'function' ? support.enumPrototypes : isArrayLike(object))) {\n    return shimKeys(object);\n  }\n  return isObject(object) ? nativeKeys(object) : [];\n};\n\nmodule.exports = keys;\n","var arrayEach = require('../internal/arrayEach'),\n    isArguments = require('../lang/isArguments'),\n    isArray = require('../lang/isArray'),\n    isFunction = require('../lang/isFunction'),\n    isIndex = require('../internal/isIndex'),\n    isLength = require('../internal/isLength'),\n    isObject = require('../lang/isObject'),\n    isString = require('../lang/isString'),\n    support = require('../support');\n\n/** `Object#toString` result references. */\nvar arrayTag = '[object Array]',\n    boolTag = '[object Boolean]',\n    dateTag = '[object Date]',\n    errorTag = '[object Error]',\n    funcTag = '[object Function]',\n    numberTag = '[object Number]',\n    objectTag = '[object Object]',\n    regexpTag = '[object RegExp]',\n    stringTag = '[object String]';\n\n/** Used to fix the JScript `[[DontEnum]]` bug. */\nvar shadowProps = [\n  'constructor', 'hasOwnProperty', 'isPrototypeOf', 'propertyIsEnumerable',\n  'toLocaleString', 'toString', 'valueOf'\n];\n\n/** Used for native method references. */\nvar errorProto = Error.prototype,\n    objectProto = Object.prototype,\n    stringProto = String.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objToString = objectProto.toString;\n\n/** Used to avoid iterating over non-enumerable properties in IE < 9. */\nvar nonEnumProps = {};\nnonEnumProps[arrayTag] = nonEnumProps[dateTag] = nonEnumProps[numberTag] = { 'constructor': true, 'toLocaleString': true, 'toString': true, 'valueOf': true };\nnonEnumProps[boolTag] = nonEnumProps[stringTag] = { 'constructor': true, 'toString': true, 'valueOf': true };\nnonEnumProps[errorTag] = nonEnumProps[funcTag] = nonEnumProps[regexpTag] = { 'constructor': true, 'toString': true };\nnonEnumProps[objectTag] = { 'constructor': true };\n\narrayEach(shadowProps, function(key) {\n  for (var tag in nonEnumProps) {\n    if (hasOwnProperty.call(nonEnumProps, tag)) {\n      var props = nonEnumProps[tag];\n      props[key] = hasOwnProperty.call(props, key);\n    }\n  }\n});\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n  if (object == null) {\n    return [];\n  }\n  if (!isObject(object)) {\n    object = Object(object);\n  }\n  var length = object.length;\n\n  length = (length && isLength(length) &&\n    (isArray(object) || isArguments(object) || isString(object)) && length) || 0;\n\n  var Ctor = object.constructor,\n      index = -1,\n      proto = (isFunction(Ctor) && Ctor.prototype) || objectProto,\n      isProto = proto === object,\n      result = Array(length),\n      skipIndexes = length > 0,\n      skipErrorProps = support.enumErrorProps && (object === errorProto || object instanceof Error),\n      skipProto = support.enumPrototypes && isFunction(object);\n\n  while (++index < length) {\n    result[index] = (index + '');\n  }\n  // lodash skips the `constructor` property when it infers it's iterating\n  // over a `prototype` object because IE < 9 can't set the `[[Enumerable]]`\n  // attribute of an existing property and the `constructor` property of a\n  // prototype defaults to non-enumerable.\n  for (var key in object) {\n    if (!(skipProto && key == 'prototype') &&\n        !(skipErrorProps && (key == 'message' || key == 'name')) &&\n        !(skipIndexes && isIndex(key, length)) &&\n        !(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n      result.push(key);\n    }\n  }\n  if (support.nonEnumShadows && object !== objectProto) {\n    var tag = object === stringProto ? stringTag : (object === errorProto ? errorTag : objToString.call(object)),\n        nonEnums = nonEnumProps[tag] || nonEnumProps[objectTag];\n\n    if (tag == objectTag) {\n      proto = objectProto;\n    }\n    length = shadowProps.length;\n    while (length--) {\n      key = shadowProps[length];\n      var nonEnum = nonEnums[key];\n      if (!(isProto && nonEnum) &&\n          (nonEnum ? hasOwnProperty.call(object, key) : object[key] !== proto[key])) {\n        result.push(key);\n      }\n    }\n  }\n  return result;\n}\n\nmodule.exports = keysIn;\n","var keys = require('./keys'),\n    toObject = require('../internal/toObject');\n\n/**\n * Creates a two dimensional array of the key-value pairs for `object`,\n * e.g. `[[key1, value1], [key2, value2]]`.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the new array of key-value pairs.\n * @example\n *\n * _.pairs({ 'barney': 36, 'fred': 40 });\n * // => [['barney', 36], ['fred', 40]] (iteration order is not guaranteed)\n */\nfunction pairs(object) {\n  object = toObject(object);\n\n  var index = -1,\n      props = keys(object),\n      length = props.length,\n      result = Array(length);\n\n  while (++index < length) {\n    var key = props[index];\n    result[index] = [key, object[key]];\n  }\n  return result;\n}\n\nmodule.exports = pairs;\n","var baseValues = require('../internal/baseValues'),\n    keys = require('./keys');\n\n/**\n * Creates an array of the own enumerable property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\nfunction values(object) {\n  return baseValues(object, keys(object));\n}\n\nmodule.exports = values;\n","/** Used for native method references. */\nvar arrayProto = Array.prototype,\n    errorProto = Error.prototype,\n    objectProto = Object.prototype;\n\n/** Native method references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable,\n    splice = arrayProto.splice;\n\n/**\n * An object environment feature flags.\n *\n * @static\n * @memberOf _\n * @type Object\n */\nvar support = {};\n\n(function(x) {\n  var Ctor = function() { this.x = x; },\n      object = { '0': x, 'length': x },\n      props = [];\n\n  Ctor.prototype = { 'valueOf': x, 'y': x };\n  for (var key in new Ctor) { props.push(key); }\n\n  /**\n   * Detect if `name` or `message` properties of `Error.prototype` are\n   * enumerable by default (IE < 9, Safari < 5.1).\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.enumErrorProps = propertyIsEnumerable.call(errorProto, 'message') ||\n    propertyIsEnumerable.call(errorProto, 'name');\n\n  /**\n   * Detect if `prototype` properties are enumerable by default.\n   *\n   * Firefox < 3.6, Opera > 9.50 - Opera < 11.60, and Safari < 5.1\n   * (if the prototype or a property on the prototype has been set)\n   * incorrectly set the `[[Enumerable]]` value of a function's `prototype`\n   * property to `true`.\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.enumPrototypes = propertyIsEnumerable.call(Ctor, 'prototype');\n\n  /**\n   * Detect if properties shadowing those on `Object.prototype` are non-enumerable.\n   *\n   * In IE < 9 an object's own properties, shadowing non-enumerable ones,\n   * are made non-enumerable as well (a.k.a the JScript `[[DontEnum]]` bug).\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.nonEnumShadows = !/valueOf/.test(props);\n\n  /**\n   * Detect if own properties are iterated after inherited properties (IE < 9).\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.ownLast = props[0] != 'x';\n\n  /**\n   * Detect if `Array#shift` and `Array#splice` augment array-like objects\n   * correctly.\n   *\n   * Firefox < 10, compatibility modes of IE 8, and IE < 9 have buggy Array\n   * `shift()` and `splice()` functions that fail to remove the last element,\n   * `value[0]`, of array-like objects even though the \"length\" property is\n   * set to `0`. The `shift()` method is buggy in compatibility modes of IE 8,\n   * while `splice()` is buggy regardless of mode in IE < 9.\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.spliceObjects = (splice.call(object, 0, 1), !object[0]);\n\n  /**\n   * Detect lack of support for accessing string characters by index.\n   *\n   * IE < 8 can't access characters by index. IE 8 can only access characters\n   * by index on string literals, not string objects.\n   *\n   * @memberOf _.support\n   * @type boolean\n   */\n  support.unindexedChars = ('x'[0] + Object('x')[0]) != 'xx';\n}(1, 0));\n\nmodule.exports = support;\n","/**\n * This method returns the first argument provided to it.\n *\n * @static\n * @memberOf _\n * @category Utility\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'user': 'fred' };\n *\n * _.identity(object) === object;\n * // => true\n */\nfunction identity(value) {\n  return value;\n}\n\nmodule.exports = identity;\n","/**\n * A no-operation function that returns `undefined` regardless of the\n * arguments it receives.\n *\n * @static\n * @memberOf _\n * @category Utility\n * @example\n *\n * var object = { 'user': 'fred' };\n *\n * _.noop(object) === undefined;\n * // => true\n */\nfunction noop() {\n  // No operation performed.\n}\n\nmodule.exports = noop;\n","var baseProperty = require('../internal/baseProperty'),\n    basePropertyDeep = require('../internal/basePropertyDeep'),\n    isKey = require('../internal/isKey');\n\n/**\n * Creates a function that returns the property value at `path` on a\n * given object.\n *\n * @static\n * @memberOf _\n * @category Utility\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var objects = [\n *   { 'a': { 'b': { 'c': 2 } } },\n *   { 'a': { 'b': { 'c': 1 } } }\n * ];\n *\n * _.map(objects, _.property('a.b.c'));\n * // => [2, 1]\n *\n * _.pluck(_.sortBy(objects, _.property(['a', 'b', 'c'])), 'a.b.c');\n * // => [1, 2]\n */\nfunction property(path) {\n  return isKey(path) ? baseProperty(path) : basePropertyDeep(path);\n}\n\nmodule.exports = property;\n","(function (process){\n// vim:ts=4:sts=4:sw=4:\n/*!\n *\n * Copyright 2009-2012 Kris Kowal under the terms of the MIT\n * license found at http://github.com/kriskowal/q/raw/master/LICENSE\n *\n * With parts by Tyler Close\n * Copyright 2007-2009 Tyler Close under the terms of the MIT X license found\n * at http://www.opensource.org/licenses/mit-license.html\n * Forked at ref_send.js version: 2009-05-11\n *\n * With parts by Mark Miller\n * Copyright (C) 2011 Google Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\n(function (definition) {\n    \"use strict\";\n\n    // This file will function properly as a <script> tag, or a module\n    // using CommonJS and NodeJS or RequireJS module formats.  In\n    // Common/Node/RequireJS, the module exports the Q API and when\n    // executed as a simple <script>, it creates a Q global instead.\n\n    // Montage Require\n    if (typeof bootstrap === \"function\") {\n        bootstrap(\"promise\", definition);\n\n    // CommonJS\n    } else if (typeof exports === \"object\" && typeof module === \"object\") {\n        module.exports = definition();\n\n    // RequireJS\n    } else if (typeof define === \"function\" && define.amd) {\n        define(definition);\n\n    // SES (Secure EcmaScript)\n    } else if (typeof ses !== \"undefined\") {\n        if (!ses.ok()) {\n            return;\n        } else {\n            ses.makeQ = definition;\n        }\n\n    // <script>\n    } else if (typeof window !== \"undefined\" || typeof self !== \"undefined\") {\n        // Prefer window over self for add-on scripts. Use self for\n        // non-windowed contexts.\n        var global = typeof window !== \"undefined\" ? window : self;\n\n        // Get the `window` object, save the previous Q global\n        // and initialize Q as a global.\n        var previousQ = global.Q;\n        global.Q = definition();\n\n        // Add a noConflict function so Q can be removed from the\n        // global namespace.\n        global.Q.noConflict = function () {\n            global.Q = previousQ;\n            return this;\n        };\n\n    } else {\n        throw new Error(\"This environment was not anticipated by Q. Please file a bug.\");\n    }\n\n})(function () {\n\"use strict\";\n\nvar hasStacks = false;\ntry {\n    throw new Error();\n} catch (e) {\n    hasStacks = !!e.stack;\n}\n\n// All code after this point will be filtered from stack traces reported\n// by Q.\nvar qStartingLine = captureLine();\nvar qFileName;\n\n// shims\n\n// used for fallback in \"allResolved\"\nvar noop = function () {};\n\n// Use the fastest possible means to execute a task in a future turn\n// of the event loop.\nvar nextTick =(function () {\n    // linked list of tasks (single, with head node)\n    var head = {task: void 0, next: null};\n    var tail = head;\n    var flushing = false;\n    var requestTick = void 0;\n    var isNodeJS = false;\n    // queue for late tasks, used by unhandled rejection tracking\n    var laterQueue = [];\n\n    function flush() {\n        /* jshint loopfunc: true */\n        var task, domain;\n\n        while (head.next) {\n            head = head.next;\n            task = head.task;\n            head.task = void 0;\n            domain = head.domain;\n\n            if (domain) {\n                head.domain = void 0;\n                domain.enter();\n            }\n            runSingle(task, domain);\n\n        }\n        while (laterQueue.length) {\n            task = laterQueue.pop();\n            runSingle(task);\n        }\n        flushing = false;\n    }\n    // runs a single function in the async queue\n    function runSingle(task, domain) {\n        try {\n            task();\n\n        } catch (e) {\n            if (isNodeJS) {\n                // In node, uncaught exceptions are considered fatal errors.\n                // Re-throw them synchronously to interrupt flushing!\n\n                // Ensure continuation if the uncaught exception is suppressed\n                // listening \"uncaughtException\" events (as domains does).\n                // Continue in next event to avoid tick recursion.\n                if (domain) {\n                    domain.exit();\n                }\n                setTimeout(flush, 0);\n                if (domain) {\n                    domain.enter();\n                }\n\n                throw e;\n\n            } else {\n                // In browsers, uncaught exceptions are not fatal.\n                // Re-throw them asynchronously to avoid slow-downs.\n                setTimeout(function () {\n                    throw e;\n                }, 0);\n            }\n        }\n\n        if (domain) {\n            domain.exit();\n        }\n    }\n\n    nextTick = function (task) {\n        tail = tail.next = {\n            task: task,\n            domain: isNodeJS && process.domain,\n            next: null\n        };\n\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n\n    if (typeof process === \"object\" &&\n        process.toString() === \"[object process]\" && process.nextTick) {\n        // Ensure Q is in a real Node environment, with a `process.nextTick`.\n        // To see through fake Node environments:\n        // * Mocha test runner - exposes a `process` global without a `nextTick`\n        // * Browserify - exposes a `process.nexTick` function that uses\n        //   `setTimeout`. In this case `setImmediate` is preferred because\n        //    it is faster. Browserify's `process.toString()` yields\n        //   \"[object Object]\", while in a real Node environment\n        //   `process.nextTick()` yields \"[object process]\".\n        isNodeJS = true;\n\n        requestTick = function () {\n            process.nextTick(flush);\n        };\n\n    } else if (typeof setImmediate === \"function\") {\n        // In IE10, Node.js 0.9+, or https://github.com/NobleJS/setImmediate\n        if (typeof window !== \"undefined\") {\n            requestTick = setImmediate.bind(window, flush);\n        } else {\n            requestTick = function () {\n                setImmediate(flush);\n            };\n        }\n\n    } else if (typeof MessageChannel !== \"undefined\") {\n        // modern browsers\n        // http://www.nonblocking.io/2011/06/windownexttick.html\n        var channel = new MessageChannel();\n        // At least Safari Version 6.0.5 (8536.30.1) intermittently cannot create\n        // working message ports the first time a page loads.\n        channel.port1.onmessage = function () {\n            requestTick = requestPortTick;\n            channel.port1.onmessage = flush;\n            flush();\n        };\n        var requestPortTick = function () {\n            // Opera requires us to provide a message payload, regardless of\n            // whether we use it.\n            channel.port2.postMessage(0);\n        };\n        requestTick = function () {\n            setTimeout(flush, 0);\n            requestPortTick();\n        };\n\n    } else {\n        // old browsers\n        requestTick = function () {\n            setTimeout(flush, 0);\n        };\n    }\n    // runs a task after all other tasks have been run\n    // this is useful for unhandled rejection tracking that needs to happen\n    // after all `then`d tasks have been run.\n    nextTick.runAfter = function (task) {\n        laterQueue.push(task);\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n    return nextTick;\n})();\n\n// Attempt to make generics safe in the face of downstream\n// modifications.\n// There is no situation where this is necessary.\n// If you need a security guarantee, these primordials need to be\n// deeply frozen anyway, and if you don’t need a security guarantee,\n// this is just plain paranoid.\n// However, this **might** have the nice side-effect of reducing the size of\n// the minified code by reducing x.call() to merely x()\n// See Mark Miller’s explanation of what this does.\n// http://wiki.ecmascript.org/doku.php?id=conventions:safe_meta_programming\nvar call = Function.call;\nfunction uncurryThis(f) {\n    return function () {\n        return call.apply(f, arguments);\n    };\n}\n// This is equivalent, but slower:\n// uncurryThis = Function_bind.bind(Function_bind.call);\n// http://jsperf.com/uncurrythis\n\nvar array_slice = uncurryThis(Array.prototype.slice);\n\nvar array_reduce = uncurryThis(\n    Array.prototype.reduce || function (callback, basis) {\n        var index = 0,\n            length = this.length;\n        // concerning the initial value, if one is not provided\n        if (arguments.length === 1) {\n            // seek to the first value in the array, accounting\n            // for the possibility that is is a sparse array\n            do {\n                if (index in this) {\n                    basis = this[index++];\n                    break;\n                }\n                if (++index >= length) {\n                    throw new TypeError();\n                }\n            } while (1);\n        }\n        // reduce\n        for (; index < length; index++) {\n            // account for the possibility that the array is sparse\n            if (index in this) {\n                basis = callback(basis, this[index], index);\n            }\n        }\n        return basis;\n    }\n);\n\nvar array_indexOf = uncurryThis(\n    Array.prototype.indexOf || function (value) {\n        // not a very good shim, but good enough for our one use of it\n        for (var i = 0; i < this.length; i++) {\n            if (this[i] === value) {\n                return i;\n            }\n        }\n        return -1;\n    }\n);\n\nvar array_map = uncurryThis(\n    Array.prototype.map || function (callback, thisp) {\n        var self = this;\n        var collect = [];\n        array_reduce(self, function (undefined, value, index) {\n            collect.push(callback.call(thisp, value, index, self));\n        }, void 0);\n        return collect;\n    }\n);\n\nvar object_create = Object.create || function (prototype) {\n    function Type() { }\n    Type.prototype = prototype;\n    return new Type();\n};\n\nvar object_hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty);\n\nvar object_keys = Object.keys || function (object) {\n    var keys = [];\n    for (var key in object) {\n        if (object_hasOwnProperty(object, key)) {\n            keys.push(key);\n        }\n    }\n    return keys;\n};\n\nvar object_toString = uncurryThis(Object.prototype.toString);\n\nfunction isObject(value) {\n    return value === Object(value);\n}\n\n// generator related shims\n\n// FIXME: Remove this function once ES6 generators are in SpiderMonkey.\nfunction isStopIteration(exception) {\n    return (\n        object_toString(exception) === \"[object StopIteration]\" ||\n        exception instanceof QReturnValue\n    );\n}\n\n// FIXME: Remove this helper and Q.return once ES6 generators are in\n// SpiderMonkey.\nvar QReturnValue;\nif (typeof ReturnValue !== \"undefined\") {\n    QReturnValue = ReturnValue;\n} else {\n    QReturnValue = function (value) {\n        this.value = value;\n    };\n}\n\n// long stack traces\n\nvar STACK_JUMP_SEPARATOR = \"From previous event:\";\n\nfunction makeStackTraceLong(error, promise) {\n    // If possible, transform the error stack trace by removing Node and Q\n    // cruft, then concatenating with the stack trace of `promise`. See #57.\n    if (hasStacks &&\n        promise.stack &&\n        typeof error === \"object\" &&\n        error !== null &&\n        error.stack &&\n        error.stack.indexOf(STACK_JUMP_SEPARATOR) === -1\n    ) {\n        var stacks = [];\n        for (var p = promise; !!p; p = p.source) {\n            if (p.stack) {\n                stacks.unshift(p.stack);\n            }\n        }\n        stacks.unshift(error.stack);\n\n        var concatedStacks = stacks.join(\"\\n\" + STACK_JUMP_SEPARATOR + \"\\n\");\n        error.stack = filterStackString(concatedStacks);\n    }\n}\n\nfunction filterStackString(stackString) {\n    var lines = stackString.split(\"\\n\");\n    var desiredLines = [];\n    for (var i = 0; i < lines.length; ++i) {\n        var line = lines[i];\n\n        if (!isInternalFrame(line) && !isNodeFrame(line) && line) {\n            desiredLines.push(line);\n        }\n    }\n    return desiredLines.join(\"\\n\");\n}\n\nfunction isNodeFrame(stackLine) {\n    return stackLine.indexOf(\"(module.js:\") !== -1 ||\n           stackLine.indexOf(\"(node.js:\") !== -1;\n}\n\nfunction getFileNameAndLineNumber(stackLine) {\n    // Named functions: \"at functionName (filename:lineNumber:columnNumber)\"\n    // In IE10 function name can have spaces (\"Anonymous function\") O_o\n    var attempt1 = /at .+ \\((.+):(\\d+):(?:\\d+)\\)$/.exec(stackLine);\n    if (attempt1) {\n        return [attempt1[1], Number(attempt1[2])];\n    }\n\n    // Anonymous functions: \"at filename:lineNumber:columnNumber\"\n    var attempt2 = /at ([^ ]+):(\\d+):(?:\\d+)$/.exec(stackLine);\n    if (attempt2) {\n        return [attempt2[1], Number(attempt2[2])];\n    }\n\n    // Firefox style: \"function@filename:lineNumber or @filename:lineNumber\"\n    var attempt3 = /.*@(.+):(\\d+)$/.exec(stackLine);\n    if (attempt3) {\n        return [attempt3[1], Number(attempt3[2])];\n    }\n}\n\nfunction isInternalFrame(stackLine) {\n    var fileNameAndLineNumber = getFileNameAndLineNumber(stackLine);\n\n    if (!fileNameAndLineNumber) {\n        return false;\n    }\n\n    var fileName = fileNameAndLineNumber[0];\n    var lineNumber = fileNameAndLineNumber[1];\n\n    return fileName === qFileName &&\n        lineNumber >= qStartingLine &&\n        lineNumber <= qEndingLine;\n}\n\n// discover own file name and line number range for filtering stack\n// traces\nfunction captureLine() {\n    if (!hasStacks) {\n        return;\n    }\n\n    try {\n        throw new Error();\n    } catch (e) {\n        var lines = e.stack.split(\"\\n\");\n        var firstLine = lines[0].indexOf(\"@\") > 0 ? lines[1] : lines[2];\n        var fileNameAndLineNumber = getFileNameAndLineNumber(firstLine);\n        if (!fileNameAndLineNumber) {\n            return;\n        }\n\n        qFileName = fileNameAndLineNumber[0];\n        return fileNameAndLineNumber[1];\n    }\n}\n\nfunction deprecate(callback, name, alternative) {\n    return function () {\n        if (typeof console !== \"undefined\" &&\n            typeof console.warn === \"function\") {\n            console.warn(name + \" is deprecated, use \" + alternative +\n                         \" instead.\", new Error(\"\").stack);\n        }\n        return callback.apply(callback, arguments);\n    };\n}\n\n// end of shims\n// beginning of real work\n\n/**\n * Constructs a promise for an immediate reference, passes promises through, or\n * coerces promises from different systems.\n * @param value immediate reference or promise\n */\nfunction Q(value) {\n    // If the object is already a Promise, return it directly.  This enables\n    // the resolve function to both be used to created references from objects,\n    // but to tolerably coerce non-promises to promises.\n    if (value instanceof Promise) {\n        return value;\n    }\n\n    // assimilate thenables\n    if (isPromiseAlike(value)) {\n        return coerce(value);\n    } else {\n        return fulfill(value);\n    }\n}\nQ.resolve = Q;\n\n/**\n * Performs a task in a future turn of the event loop.\n * @param {Function} task\n */\nQ.nextTick = nextTick;\n\n/**\n * Controls whether or not long stack traces will be on\n */\nQ.longStackSupport = false;\n\n// enable long stacks if Q_DEBUG is set\nif (typeof process === \"object\" && process && process.env && process.env.Q_DEBUG) {\n    Q.longStackSupport = true;\n}\n\n/**\n * Constructs a {promise, resolve, reject} object.\n *\n * `resolve` is a callback to invoke with a more resolved value for the\n * promise. To fulfill the promise, invoke `resolve` with any value that is\n * not a thenable. To reject the promise, invoke `resolve` with a rejected\n * thenable, or invoke `reject` with the reason directly. To resolve the\n * promise to another thenable, thus putting it in the same state, invoke\n * `resolve` with that other thenable.\n */\nQ.defer = defer;\nfunction defer() {\n    // if \"messages\" is an \"Array\", that indicates that the promise has not yet\n    // been resolved.  If it is \"undefined\", it has been resolved.  Each\n    // element of the messages array is itself an array of complete arguments to\n    // forward to the resolved promise.  We coerce the resolution value to a\n    // promise using the `resolve` function because it handles both fully\n    // non-thenable values and other thenables gracefully.\n    var messages = [], progressListeners = [], resolvedPromise;\n\n    var deferred = object_create(defer.prototype);\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, operands) {\n        var args = array_slice(arguments);\n        if (messages) {\n            messages.push(args);\n            if (op === \"when\" && operands[1]) { // progress operand\n                progressListeners.push(operands[1]);\n            }\n        } else {\n            Q.nextTick(function () {\n                resolvedPromise.promiseDispatch.apply(resolvedPromise, args);\n            });\n        }\n    };\n\n    // XXX deprecated\n    promise.valueOf = function () {\n        if (messages) {\n            return promise;\n        }\n        var nearerValue = nearer(resolvedPromise);\n        if (isPromise(nearerValue)) {\n            resolvedPromise = nearerValue; // shorten chain\n        }\n        return nearerValue;\n    };\n\n    promise.inspect = function () {\n        if (!resolvedPromise) {\n            return { state: \"pending\" };\n        }\n        return resolvedPromise.inspect();\n    };\n\n    if (Q.longStackSupport && hasStacks) {\n        try {\n            throw new Error();\n        } catch (e) {\n            // NOTE: don't try to use `Error.captureStackTrace` or transfer the\n            // accessor around; that causes memory leaks as per GH-111. Just\n            // reify the stack trace as a string ASAP.\n            //\n            // At the same time, cut off the first line; it's always just\n            // \"[object Promise]\\n\", as per the `toString`.\n            promise.stack = e.stack.substring(e.stack.indexOf(\"\\n\") + 1);\n        }\n    }\n\n    // NOTE: we do the checks for `resolvedPromise` in each method, instead of\n    // consolidating them into `become`, since otherwise we'd create new\n    // promises with the lines `become(whatever(value))`. See e.g. GH-252.\n\n    function become(newPromise) {\n        resolvedPromise = newPromise;\n        promise.source = newPromise;\n\n        array_reduce(messages, function (undefined, message) {\n            Q.nextTick(function () {\n                newPromise.promiseDispatch.apply(newPromise, message);\n            });\n        }, void 0);\n\n        messages = void 0;\n        progressListeners = void 0;\n    }\n\n    deferred.promise = promise;\n    deferred.resolve = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(Q(value));\n    };\n\n    deferred.fulfill = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(fulfill(value));\n    };\n    deferred.reject = function (reason) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(reject(reason));\n    };\n    deferred.notify = function (progress) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        array_reduce(progressListeners, function (undefined, progressListener) {\n            Q.nextTick(function () {\n                progressListener(progress);\n            });\n        }, void 0);\n    };\n\n    return deferred;\n}\n\n/**\n * Creates a Node-style callback that will resolve or reject the deferred\n * promise.\n * @returns a nodeback\n */\ndefer.prototype.makeNodeResolver = function () {\n    var self = this;\n    return function (error, value) {\n        if (error) {\n            self.reject(error);\n        } else if (arguments.length > 2) {\n            self.resolve(array_slice(arguments, 1));\n        } else {\n            self.resolve(value);\n        }\n    };\n};\n\n/**\n * @param resolver {Function} a function that returns nothing and accepts\n * the resolve, reject, and notify functions for a deferred.\n * @returns a promise that may be resolved with the given resolve and reject\n * functions, or rejected by a thrown exception in resolver\n */\nQ.Promise = promise; // ES6\nQ.promise = promise;\nfunction promise(resolver) {\n    if (typeof resolver !== \"function\") {\n        throw new TypeError(\"resolver must be a function.\");\n    }\n    var deferred = defer();\n    try {\n        resolver(deferred.resolve, deferred.reject, deferred.notify);\n    } catch (reason) {\n        deferred.reject(reason);\n    }\n    return deferred.promise;\n}\n\npromise.race = race; // ES6\npromise.all = all; // ES6\npromise.reject = reject; // ES6\npromise.resolve = Q; // ES6\n\n// XXX experimental.  This method is a way to denote that a local value is\n// serializable and should be immediately dispatched to a remote upon request,\n// instead of passing a reference.\nQ.passByCopy = function (object) {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return object;\n};\n\nPromise.prototype.passByCopy = function () {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return this;\n};\n\n/**\n * If two promises eventually fulfill to the same value, promises that value,\n * but otherwise rejects.\n * @param x {Any*}\n * @param y {Any*}\n * @returns {Any*} a promise for x and y if they are the same, but a rejection\n * otherwise.\n *\n */\nQ.join = function (x, y) {\n    return Q(x).join(y);\n};\n\nPromise.prototype.join = function (that) {\n    return Q([this, that]).spread(function (x, y) {\n        if (x === y) {\n            // TODO: \"===\" should be Object.is or equiv\n            return x;\n        } else {\n            throw new Error(\"Can't join: not the same: \" + x + \" \" + y);\n        }\n    });\n};\n\n/**\n * Returns a promise for the first of an array of promises to become settled.\n * @param answers {Array[Any*]} promises to race\n * @returns {Any*} the first promise to be settled\n */\nQ.race = race;\nfunction race(answerPs) {\n    return promise(function (resolve, reject) {\n        // Switch to this once we can assume at least ES5\n        // answerPs.forEach(function (answerP) {\n        //     Q(answerP).then(resolve, reject);\n        // });\n        // Use this in the meantime\n        for (var i = 0, len = answerPs.length; i < len; i++) {\n            Q(answerPs[i]).then(resolve, reject);\n        }\n    });\n}\n\nPromise.prototype.race = function () {\n    return this.then(Q.race);\n};\n\n/**\n * Constructs a Promise with a promise descriptor object and optional fallback\n * function.  The descriptor contains methods like when(rejected), get(name),\n * set(name, value), post(name, args), and delete(name), which all\n * return either a value, a promise for a value, or a rejection.  The fallback\n * accepts the operation name, a resolver, and any further arguments that would\n * have been forwarded to the appropriate method above had a method been\n * provided with the proper name.  The API makes no guarantees about the nature\n * of the returned object, apart from that it is usable whereever promises are\n * bought and sold.\n */\nQ.makePromise = Promise;\nfunction Promise(descriptor, fallback, inspect) {\n    if (fallback === void 0) {\n        fallback = function (op) {\n            return reject(new Error(\n                \"Promise does not support operation: \" + op\n            ));\n        };\n    }\n    if (inspect === void 0) {\n        inspect = function () {\n            return {state: \"unknown\"};\n        };\n    }\n\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, args) {\n        var result;\n        try {\n            if (descriptor[op]) {\n                result = descriptor[op].apply(promise, args);\n            } else {\n                result = fallback.call(promise, op, args);\n            }\n        } catch (exception) {\n            result = reject(exception);\n        }\n        if (resolve) {\n            resolve(result);\n        }\n    };\n\n    promise.inspect = inspect;\n\n    // XXX deprecated `valueOf` and `exception` support\n    if (inspect) {\n        var inspected = inspect();\n        if (inspected.state === \"rejected\") {\n            promise.exception = inspected.reason;\n        }\n\n        promise.valueOf = function () {\n            var inspected = inspect();\n            if (inspected.state === \"pending\" ||\n                inspected.state === \"rejected\") {\n                return promise;\n            }\n            return inspected.value;\n        };\n    }\n\n    return promise;\n}\n\nPromise.prototype.toString = function () {\n    return \"[object Promise]\";\n};\n\nPromise.prototype.then = function (fulfilled, rejected, progressed) {\n    var self = this;\n    var deferred = defer();\n    var done = false;   // ensure the untrusted promise makes at most a\n                        // single call to one of the callbacks\n\n    function _fulfilled(value) {\n        try {\n            return typeof fulfilled === \"function\" ? fulfilled(value) : value;\n        } catch (exception) {\n            return reject(exception);\n        }\n    }\n\n    function _rejected(exception) {\n        if (typeof rejected === \"function\") {\n            makeStackTraceLong(exception, self);\n            try {\n                return rejected(exception);\n            } catch (newException) {\n                return reject(newException);\n            }\n        }\n        return reject(exception);\n    }\n\n    function _progressed(value) {\n        return typeof progressed === \"function\" ? progressed(value) : value;\n    }\n\n    Q.nextTick(function () {\n        self.promiseDispatch(function (value) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_fulfilled(value));\n        }, \"when\", [function (exception) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_rejected(exception));\n        }]);\n    });\n\n    // Progress propagator need to be attached in the current tick.\n    self.promiseDispatch(void 0, \"when\", [void 0, function (value) {\n        var newValue;\n        var threw = false;\n        try {\n            newValue = _progressed(value);\n        } catch (e) {\n            threw = true;\n            if (Q.onerror) {\n                Q.onerror(e);\n            } else {\n                throw e;\n            }\n        }\n\n        if (!threw) {\n            deferred.notify(newValue);\n        }\n    }]);\n\n    return deferred.promise;\n};\n\nQ.tap = function (promise, callback) {\n    return Q(promise).tap(callback);\n};\n\n/**\n * Works almost like \"finally\", but not called for rejections.\n * Original resolution value is passed through callback unaffected.\n * Callback may return a promise that will be awaited for.\n * @param {Function} callback\n * @returns {Q.Promise}\n * @example\n * doSomething()\n *   .then(...)\n *   .tap(console.log)\n *   .then(...);\n */\nPromise.prototype.tap = function (callback) {\n    callback = Q(callback);\n\n    return this.then(function (value) {\n        return callback.fcall(value).thenResolve(value);\n    });\n};\n\n/**\n * Registers an observer on a promise.\n *\n * Guarantees:\n *\n * 1. that fulfilled and rejected will be called only once.\n * 2. that either the fulfilled callback or the rejected callback will be\n *    called, but not both.\n * 3. that fulfilled and rejected will not be called in this turn.\n *\n * @param value      promise or immediate reference to observe\n * @param fulfilled  function to be called with the fulfilled value\n * @param rejected   function to be called with the rejection exception\n * @param progressed function to be called on any progress notifications\n * @return promise for the return value from the invoked callback\n */\nQ.when = when;\nfunction when(value, fulfilled, rejected, progressed) {\n    return Q(value).then(fulfilled, rejected, progressed);\n}\n\nPromise.prototype.thenResolve = function (value) {\n    return this.then(function () { return value; });\n};\n\nQ.thenResolve = function (promise, value) {\n    return Q(promise).thenResolve(value);\n};\n\nPromise.prototype.thenReject = function (reason) {\n    return this.then(function () { throw reason; });\n};\n\nQ.thenReject = function (promise, reason) {\n    return Q(promise).thenReject(reason);\n};\n\n/**\n * If an object is not a promise, it is as \"near\" as possible.\n * If a promise is rejected, it is as \"near\" as possible too.\n * If it’s a fulfilled promise, the fulfillment value is nearer.\n * If it’s a deferred promise and the deferred has been resolved, the\n * resolution is \"nearer\".\n * @param object\n * @returns most resolved (nearest) form of the object\n */\n\n// XXX should we re-do this?\nQ.nearer = nearer;\nfunction nearer(value) {\n    if (isPromise(value)) {\n        var inspected = value.inspect();\n        if (inspected.state === \"fulfilled\") {\n            return inspected.value;\n        }\n    }\n    return value;\n}\n\n/**\n * @returns whether the given object is a promise.\n * Otherwise it is a fulfilled value.\n */\nQ.isPromise = isPromise;\nfunction isPromise(object) {\n    return object instanceof Promise;\n}\n\nQ.isPromiseAlike = isPromiseAlike;\nfunction isPromiseAlike(object) {\n    return isObject(object) && typeof object.then === \"function\";\n}\n\n/**\n * @returns whether the given object is a pending promise, meaning not\n * fulfilled or rejected.\n */\nQ.isPending = isPending;\nfunction isPending(object) {\n    return isPromise(object) && object.inspect().state === \"pending\";\n}\n\nPromise.prototype.isPending = function () {\n    return this.inspect().state === \"pending\";\n};\n\n/**\n * @returns whether the given object is a value or fulfilled\n * promise.\n */\nQ.isFulfilled = isFulfilled;\nfunction isFulfilled(object) {\n    return !isPromise(object) || object.inspect().state === \"fulfilled\";\n}\n\nPromise.prototype.isFulfilled = function () {\n    return this.inspect().state === \"fulfilled\";\n};\n\n/**\n * @returns whether the given object is a rejected promise.\n */\nQ.isRejected = isRejected;\nfunction isRejected(object) {\n    return isPromise(object) && object.inspect().state === \"rejected\";\n}\n\nPromise.prototype.isRejected = function () {\n    return this.inspect().state === \"rejected\";\n};\n\n//// BEGIN UNHANDLED REJECTION TRACKING\n\n// This promise library consumes exceptions thrown in handlers so they can be\n// handled by a subsequent promise.  The exceptions get added to this array when\n// they are created, and removed when they are handled.  Note that in ES6 or\n// shimmed environments, this would naturally be a `Set`.\nvar unhandledReasons = [];\nvar unhandledRejections = [];\nvar reportedUnhandledRejections = [];\nvar trackUnhandledRejections = true;\n\nfunction resetUnhandledRejections() {\n    unhandledReasons.length = 0;\n    unhandledRejections.length = 0;\n\n    if (!trackUnhandledRejections) {\n        trackUnhandledRejections = true;\n    }\n}\n\nfunction trackRejection(promise, reason) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n    if (typeof process === \"object\" && typeof process.emit === \"function\") {\n        Q.nextTick.runAfter(function () {\n            if (array_indexOf(unhandledRejections, promise) !== -1) {\n                process.emit(\"unhandledRejection\", reason, promise);\n                reportedUnhandledRejections.push(promise);\n            }\n        });\n    }\n\n    unhandledRejections.push(promise);\n    if (reason && typeof reason.stack !== \"undefined\") {\n        unhandledReasons.push(reason.stack);\n    } else {\n        unhandledReasons.push(\"(no stack) \" + reason);\n    }\n}\n\nfunction untrackRejection(promise) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n\n    var at = array_indexOf(unhandledRejections, promise);\n    if (at !== -1) {\n        if (typeof process === \"object\" && typeof process.emit === \"function\") {\n            Q.nextTick.runAfter(function () {\n                var atReport = array_indexOf(reportedUnhandledRejections, promise);\n                if (atReport !== -1) {\n                    process.emit(\"rejectionHandled\", unhandledReasons[at], promise);\n                    reportedUnhandledRejections.splice(atReport, 1);\n                }\n            });\n        }\n        unhandledRejections.splice(at, 1);\n        unhandledReasons.splice(at, 1);\n    }\n}\n\nQ.resetUnhandledRejections = resetUnhandledRejections;\n\nQ.getUnhandledReasons = function () {\n    // Make a copy so that consumers can't interfere with our internal state.\n    return unhandledReasons.slice();\n};\n\nQ.stopUnhandledRejectionTracking = function () {\n    resetUnhandledRejections();\n    trackUnhandledRejections = false;\n};\n\nresetUnhandledRejections();\n\n//// END UNHANDLED REJECTION TRACKING\n\n/**\n * Constructs a rejected promise.\n * @param reason value describing the failure\n */\nQ.reject = reject;\nfunction reject(reason) {\n    var rejection = Promise({\n        \"when\": function (rejected) {\n            // note that the error has been handled\n            if (rejected) {\n                untrackRejection(this);\n            }\n            return rejected ? rejected(reason) : this;\n        }\n    }, function fallback() {\n        return this;\n    }, function inspect() {\n        return { state: \"rejected\", reason: reason };\n    });\n\n    // Note that the reason has not been handled.\n    trackRejection(rejection, reason);\n\n    return rejection;\n}\n\n/**\n * Constructs a fulfilled promise for an immediate reference.\n * @param value immediate reference\n */\nQ.fulfill = fulfill;\nfunction fulfill(value) {\n    return Promise({\n        \"when\": function () {\n            return value;\n        },\n        \"get\": function (name) {\n            return value[name];\n        },\n        \"set\": function (name, rhs) {\n            value[name] = rhs;\n        },\n        \"delete\": function (name) {\n            delete value[name];\n        },\n        \"post\": function (name, args) {\n            // Mark Miller proposes that post with no name should apply a\n            // promised function.\n            if (name === null || name === void 0) {\n                return value.apply(void 0, args);\n            } else {\n                return value[name].apply(value, args);\n            }\n        },\n        \"apply\": function (thisp, args) {\n            return value.apply(thisp, args);\n        },\n        \"keys\": function () {\n            return object_keys(value);\n        }\n    }, void 0, function inspect() {\n        return { state: \"fulfilled\", value: value };\n    });\n}\n\n/**\n * Converts thenables to Q promises.\n * @param promise thenable promise\n * @returns a Q promise\n */\nfunction coerce(promise) {\n    var deferred = defer();\n    Q.nextTick(function () {\n        try {\n            promise.then(deferred.resolve, deferred.reject, deferred.notify);\n        } catch (exception) {\n            deferred.reject(exception);\n        }\n    });\n    return deferred.promise;\n}\n\n/**\n * Annotates an object such that it will never be\n * transferred away from this process over any promise\n * communication channel.\n * @param object\n * @returns promise a wrapping of that object that\n * additionally responds to the \"isDef\" message\n * without a rejection.\n */\nQ.master = master;\nfunction master(object) {\n    return Promise({\n        \"isDef\": function () {}\n    }, function fallback(op, args) {\n        return dispatch(object, op, args);\n    }, function () {\n        return Q(object).inspect();\n    });\n}\n\n/**\n * Spreads the values of a promised array of arguments into the\n * fulfillment callback.\n * @param fulfilled callback that receives variadic arguments from the\n * promised array\n * @param rejected callback that receives the exception if the promise\n * is rejected.\n * @returns a promise for the return value or thrown exception of\n * either callback.\n */\nQ.spread = spread;\nfunction spread(value, fulfilled, rejected) {\n    return Q(value).spread(fulfilled, rejected);\n}\n\nPromise.prototype.spread = function (fulfilled, rejected) {\n    return this.all().then(function (array) {\n        return fulfilled.apply(void 0, array);\n    }, rejected);\n};\n\n/**\n * The async function is a decorator for generator functions, turning\n * them into asynchronous generators.  Although generators are only part\n * of the newest ECMAScript 6 drafts, this code does not cause syntax\n * errors in older engines.  This code should continue to work and will\n * in fact improve over time as the language improves.\n *\n * ES6 generators are currently part of V8 version 3.19 with the\n * --harmony-generators runtime flag enabled.  SpiderMonkey has had them\n * for longer, but under an older Python-inspired form.  This function\n * works on both kinds of generators.\n *\n * Decorates a generator function such that:\n *  - it may yield promises\n *  - execution will continue when that promise is fulfilled\n *  - the value of the yield expression will be the fulfilled value\n *  - it returns a promise for the return value (when the generator\n *    stops iterating)\n *  - the decorated function returns a promise for the return value\n *    of the generator or the first rejected promise among those\n *    yielded.\n *  - if an error is thrown in the generator, it propagates through\n *    every following yield until it is caught, or until it escapes\n *    the generator function altogether, and is translated into a\n *    rejection for the promise returned by the decorated generator.\n */\nQ.async = async;\nfunction async(makeGenerator) {\n    return function () {\n        // when verb is \"send\", arg is a value\n        // when verb is \"throw\", arg is an exception\n        function continuer(verb, arg) {\n            var result;\n\n            // Until V8 3.19 / Chromium 29 is released, SpiderMonkey is the only\n            // engine that has a deployed base of browsers that support generators.\n            // However, SM's generators use the Python-inspired semantics of\n            // outdated ES6 drafts.  We would like to support ES6, but we'd also\n            // like to make it possible to use generators in deployed browsers, so\n            // we also support Python-style generators.  At some point we can remove\n            // this block.\n\n            if (typeof StopIteration === \"undefined\") {\n                // ES6 Generators\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    return reject(exception);\n                }\n                if (result.done) {\n                    return Q(result.value);\n                } else {\n                    return when(result.value, callback, errback);\n                }\n            } else {\n                // SpiderMonkey Generators\n                // FIXME: Remove this case when SM does ES6 generators.\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    if (isStopIteration(exception)) {\n                        return Q(exception.value);\n                    } else {\n                        return reject(exception);\n                    }\n                }\n                return when(result, callback, errback);\n            }\n        }\n        var generator = makeGenerator.apply(this, arguments);\n        var callback = continuer.bind(continuer, \"next\");\n        var errback = continuer.bind(continuer, \"throw\");\n        return callback();\n    };\n}\n\n/**\n * The spawn function is a small wrapper around async that immediately\n * calls the generator and also ends the promise chain, so that any\n * unhandled errors are thrown instead of forwarded to the error\n * handler. This is useful because it's extremely common to run\n * generators at the top-level to work with libraries.\n */\nQ.spawn = spawn;\nfunction spawn(makeGenerator) {\n    Q.done(Q.async(makeGenerator)());\n}\n\n// FIXME: Remove this interface once ES6 generators are in SpiderMonkey.\n/**\n * Throws a ReturnValue exception to stop an asynchronous generator.\n *\n * This interface is a stop-gap measure to support generator return\n * values in older Firefox/SpiderMonkey.  In browsers that support ES6\n * generators like Chromium 29, just use \"return\" in your generator\n * functions.\n *\n * @param value the return value for the surrounding generator\n * @throws ReturnValue exception with the value.\n * @example\n * // ES6 style\n * Q.async(function* () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      return foo + bar;\n * })\n * // Older SpiderMonkey style\n * Q.async(function () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      Q.return(foo + bar);\n * })\n */\nQ[\"return\"] = _return;\nfunction _return(value) {\n    throw new QReturnValue(value);\n}\n\n/**\n * The promised function decorator ensures that any promise arguments\n * are settled and passed as values (`this` is also settled and passed\n * as a value).  It will also ensure that the result of a function is\n * always a promise.\n *\n * @example\n * var add = Q.promised(function (a, b) {\n *     return a + b;\n * });\n * add(Q(a), Q(B));\n *\n * @param {function} callback The function to decorate\n * @returns {function} a function that has been decorated.\n */\nQ.promised = promised;\nfunction promised(callback) {\n    return function () {\n        return spread([this, all(arguments)], function (self, args) {\n            return callback.apply(self, args);\n        });\n    };\n}\n\n/**\n * sends a message to a value in a future turn\n * @param object* the recipient\n * @param op the name of the message operation, e.g., \"when\",\n * @param args further arguments to be forwarded to the operation\n * @returns result {Promise} a promise for the result of the operation\n */\nQ.dispatch = dispatch;\nfunction dispatch(object, op, args) {\n    return Q(object).dispatch(op, args);\n}\n\nPromise.prototype.dispatch = function (op, args) {\n    var self = this;\n    var deferred = defer();\n    Q.nextTick(function () {\n        self.promiseDispatch(deferred.resolve, op, args);\n    });\n    return deferred.promise;\n};\n\n/**\n * Gets the value of a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to get\n * @return promise for the property value\n */\nQ.get = function (object, key) {\n    return Q(object).dispatch(\"get\", [key]);\n};\n\nPromise.prototype.get = function (key) {\n    return this.dispatch(\"get\", [key]);\n};\n\n/**\n * Sets the value of a property in a future turn.\n * @param object    promise or immediate reference for object object\n * @param name      name of property to set\n * @param value     new value of property\n * @return promise for the return value\n */\nQ.set = function (object, key, value) {\n    return Q(object).dispatch(\"set\", [key, value]);\n};\n\nPromise.prototype.set = function (key, value) {\n    return this.dispatch(\"set\", [key, value]);\n};\n\n/**\n * Deletes a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to delete\n * @return promise for the return value\n */\nQ.del = // XXX legacy\nQ[\"delete\"] = function (object, key) {\n    return Q(object).dispatch(\"delete\", [key]);\n};\n\nPromise.prototype.del = // XXX legacy\nPromise.prototype[\"delete\"] = function (key) {\n    return this.dispatch(\"delete\", [key]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param value     a value to post, typically an array of\n *                  invocation arguments for promises that\n *                  are ultimately backed with `resolve` values,\n *                  as opposed to those backed with URLs\n *                  wherein the posted value can be any\n *                  JSON serializable object.\n * @return promise for the return value\n */\n// bound locally because it is used by other methods\nQ.mapply = // XXX As proposed by \"Redsandro\"\nQ.post = function (object, name, args) {\n    return Q(object).dispatch(\"post\", [name, args]);\n};\n\nPromise.prototype.mapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.post = function (name, args) {\n    return this.dispatch(\"post\", [name, args]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param ...args   array of invocation arguments\n * @return promise for the return value\n */\nQ.send = // XXX Mark Miller's proposed parlance\nQ.mcall = // XXX As proposed by \"Redsandro\"\nQ.invoke = function (object, name /*...args*/) {\n    return Q(object).dispatch(\"post\", [name, array_slice(arguments, 2)]);\n};\n\nPromise.prototype.send = // XXX Mark Miller's proposed parlance\nPromise.prototype.mcall = // XXX As proposed by \"Redsandro\"\nPromise.prototype.invoke = function (name /*...args*/) {\n    return this.dispatch(\"post\", [name, array_slice(arguments, 1)]);\n};\n\n/**\n * Applies the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param args      array of application arguments\n */\nQ.fapply = function (object, args) {\n    return Q(object).dispatch(\"apply\", [void 0, args]);\n};\n\nPromise.prototype.fapply = function (args) {\n    return this.dispatch(\"apply\", [void 0, args]);\n};\n\n/**\n * Calls the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ[\"try\"] =\nQ.fcall = function (object /* ...args*/) {\n    return Q(object).dispatch(\"apply\", [void 0, array_slice(arguments, 1)]);\n};\n\nPromise.prototype.fcall = function (/*...args*/) {\n    return this.dispatch(\"apply\", [void 0, array_slice(arguments)]);\n};\n\n/**\n * Binds the promised function, transforming return values into a fulfilled\n * promise and thrown errors into a rejected one.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ.fbind = function (object /*...args*/) {\n    var promise = Q(object);\n    var args = array_slice(arguments, 1);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\nPromise.prototype.fbind = function (/*...args*/) {\n    var promise = this;\n    var args = array_slice(arguments);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\n\n/**\n * Requests the names of the owned properties of a promised\n * object in a future turn.\n * @param object    promise or immediate reference for target object\n * @return promise for the keys of the eventually settled object\n */\nQ.keys = function (object) {\n    return Q(object).dispatch(\"keys\", []);\n};\n\nPromise.prototype.keys = function () {\n    return this.dispatch(\"keys\", []);\n};\n\n/**\n * Turns an array of promises into a promise for an array.  If any of\n * the promises gets rejected, the whole array is rejected immediately.\n * @param {Array*} an array (or promise for an array) of values (or\n * promises for values)\n * @returns a promise for an array of the corresponding values\n */\n// By Mark Miller\n// http://wiki.ecmascript.org/doku.php?id=strawman:concurrency&rev=1308776521#allfulfilled\nQ.all = all;\nfunction all(promises) {\n    return when(promises, function (promises) {\n        var pendingCount = 0;\n        var deferred = defer();\n        array_reduce(promises, function (undefined, promise, index) {\n            var snapshot;\n            if (\n                isPromise(promise) &&\n                (snapshot = promise.inspect()).state === \"fulfilled\"\n            ) {\n                promises[index] = snapshot.value;\n            } else {\n                ++pendingCount;\n                when(\n                    promise,\n                    function (value) {\n                        promises[index] = value;\n                        if (--pendingCount === 0) {\n                            deferred.resolve(promises);\n                        }\n                    },\n                    deferred.reject,\n                    function (progress) {\n                        deferred.notify({ index: index, value: progress });\n                    }\n                );\n            }\n        }, void 0);\n        if (pendingCount === 0) {\n            deferred.resolve(promises);\n        }\n        return deferred.promise;\n    });\n}\n\nPromise.prototype.all = function () {\n    return all(this);\n};\n\n/**\n * Returns the first resolved promise of an array. Prior rejected promises are\n * ignored.  Rejects only if all promises are rejected.\n * @param {Array*} an array containing values or promises for values\n * @returns a promise fulfilled with the value of the first resolved promise,\n * or a rejected promise if all promises are rejected.\n */\nQ.any = any;\n\nfunction any(promises) {\n    if (promises.length === 0) {\n        return Q.resolve();\n    }\n\n    var deferred = Q.defer();\n    var pendingCount = 0;\n    array_reduce(promises, function (prev, current, index) {\n        var promise = promises[index];\n\n        pendingCount++;\n\n        when(promise, onFulfilled, onRejected, onProgress);\n        function onFulfilled(result) {\n            deferred.resolve(result);\n        }\n        function onRejected() {\n            pendingCount--;\n            if (pendingCount === 0) {\n                deferred.reject(new Error(\n                    \"Can't get fulfillment value from any promise, all \" +\n                    \"promises were rejected.\"\n                ));\n            }\n        }\n        function onProgress(progress) {\n            deferred.notify({\n                index: index,\n                value: progress\n            });\n        }\n    }, undefined);\n\n    return deferred.promise;\n}\n\nPromise.prototype.any = function () {\n    return any(this);\n};\n\n/**\n * Waits for all promises to be settled, either fulfilled or\n * rejected.  This is distinct from `all` since that would stop\n * waiting at the first rejection.  The promise returned by\n * `allResolved` will never be rejected.\n * @param promises a promise for an array (or an array) of promises\n * (or values)\n * @return a promise for an array of promises\n */\nQ.allResolved = deprecate(allResolved, \"allResolved\", \"allSettled\");\nfunction allResolved(promises) {\n    return when(promises, function (promises) {\n        promises = array_map(promises, Q);\n        return when(all(array_map(promises, function (promise) {\n            return when(promise, noop, noop);\n        })), function () {\n            return promises;\n        });\n    });\n}\n\nPromise.prototype.allResolved = function () {\n    return allResolved(this);\n};\n\n/**\n * @see Promise#allSettled\n */\nQ.allSettled = allSettled;\nfunction allSettled(promises) {\n    return Q(promises).allSettled();\n}\n\n/**\n * Turns an array of promises into a promise for an array of their states (as\n * returned by `inspect`) when they have all settled.\n * @param {Array[Any*]} values an array (or promise for an array) of values (or\n * promises for values)\n * @returns {Array[State]} an array of states for the respective values.\n */\nPromise.prototype.allSettled = function () {\n    return this.then(function (promises) {\n        return all(array_map(promises, function (promise) {\n            promise = Q(promise);\n            function regardless() {\n                return promise.inspect();\n            }\n            return promise.then(regardless, regardless);\n        }));\n    });\n};\n\n/**\n * Captures the failure of a promise, giving an oportunity to recover\n * with a callback.  If the given promise is fulfilled, the returned\n * promise is fulfilled.\n * @param {Any*} promise for something\n * @param {Function} callback to fulfill the returned promise if the\n * given promise is rejected\n * @returns a promise for the return value of the callback\n */\nQ.fail = // XXX legacy\nQ[\"catch\"] = function (object, rejected) {\n    return Q(object).then(void 0, rejected);\n};\n\nPromise.prototype.fail = // XXX legacy\nPromise.prototype[\"catch\"] = function (rejected) {\n    return this.then(void 0, rejected);\n};\n\n/**\n * Attaches a listener that can respond to progress notifications from a\n * promise's originating deferred. This listener receives the exact arguments\n * passed to ``deferred.notify``.\n * @param {Any*} promise for something\n * @param {Function} callback to receive any progress notifications\n * @returns the given promise, unchanged\n */\nQ.progress = progress;\nfunction progress(object, progressed) {\n    return Q(object).then(void 0, void 0, progressed);\n}\n\nPromise.prototype.progress = function (progressed) {\n    return this.then(void 0, void 0, progressed);\n};\n\n/**\n * Provides an opportunity to observe the settling of a promise,\n * regardless of whether the promise is fulfilled or rejected.  Forwards\n * the resolution to the returned promise when the callback is done.\n * The callback can return a promise to defer completion.\n * @param {Any*} promise\n * @param {Function} callback to observe the resolution of the given\n * promise, takes no arguments.\n * @returns a promise for the resolution of the given promise when\n * ``fin`` is done.\n */\nQ.fin = // XXX legacy\nQ[\"finally\"] = function (object, callback) {\n    return Q(object)[\"finally\"](callback);\n};\n\nPromise.prototype.fin = // XXX legacy\nPromise.prototype[\"finally\"] = function (callback) {\n    callback = Q(callback);\n    return this.then(function (value) {\n        return callback.fcall().then(function () {\n            return value;\n        });\n    }, function (reason) {\n        // TODO attempt to recycle the rejection with \"this\".\n        return callback.fcall().then(function () {\n            throw reason;\n        });\n    });\n};\n\n/**\n * Terminates a chain of promises, forcing rejections to be\n * thrown as exceptions.\n * @param {Any*} promise at the end of a chain of promises\n * @returns nothing\n */\nQ.done = function (object, fulfilled, rejected, progress) {\n    return Q(object).done(fulfilled, rejected, progress);\n};\n\nPromise.prototype.done = function (fulfilled, rejected, progress) {\n    var onUnhandledError = function (error) {\n        // forward to a future turn so that ``when``\n        // does not catch it and turn it into a rejection.\n        Q.nextTick(function () {\n            makeStackTraceLong(error, promise);\n            if (Q.onerror) {\n                Q.onerror(error);\n            } else {\n                throw error;\n            }\n        });\n    };\n\n    // Avoid unnecessary `nextTick`ing via an unnecessary `when`.\n    var promise = fulfilled || rejected || progress ?\n        this.then(fulfilled, rejected, progress) :\n        this;\n\n    if (typeof process === \"object\" && process && process.domain) {\n        onUnhandledError = process.domain.bind(onUnhandledError);\n    }\n\n    promise.then(void 0, onUnhandledError);\n};\n\n/**\n * Causes a promise to be rejected if it does not get fulfilled before\n * some milliseconds time out.\n * @param {Any*} promise\n * @param {Number} milliseconds timeout\n * @param {Any*} custom error message or Error object (optional)\n * @returns a promise for the resolution of the given promise if it is\n * fulfilled before the timeout, otherwise rejected.\n */\nQ.timeout = function (object, ms, error) {\n    return Q(object).timeout(ms, error);\n};\n\nPromise.prototype.timeout = function (ms, error) {\n    var deferred = defer();\n    var timeoutId = setTimeout(function () {\n        if (!error || \"string\" === typeof error) {\n            error = new Error(error || \"Timed out after \" + ms + \" ms\");\n            error.code = \"ETIMEDOUT\";\n        }\n        deferred.reject(error);\n    }, ms);\n\n    this.then(function (value) {\n        clearTimeout(timeoutId);\n        deferred.resolve(value);\n    }, function (exception) {\n        clearTimeout(timeoutId);\n        deferred.reject(exception);\n    }, deferred.notify);\n\n    return deferred.promise;\n};\n\n/**\n * Returns a promise for the given value (or promised value), some\n * milliseconds after it resolved. Passes rejections immediately.\n * @param {Any*} promise\n * @param {Number} milliseconds\n * @returns a promise for the resolution of the given promise after milliseconds\n * time has elapsed since the resolution of the given promise.\n * If the given promise rejects, that is passed immediately.\n */\nQ.delay = function (object, timeout) {\n    if (timeout === void 0) {\n        timeout = object;\n        object = void 0;\n    }\n    return Q(object).delay(timeout);\n};\n\nPromise.prototype.delay = function (timeout) {\n    return this.then(function (value) {\n        var deferred = defer();\n        setTimeout(function () {\n            deferred.resolve(value);\n        }, timeout);\n        return deferred.promise;\n    });\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided as an array, and returns a promise.\n *\n *      Q.nfapply(FS.readFile, [__filename])\n *      .then(function (content) {\n *      })\n *\n */\nQ.nfapply = function (callback, args) {\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfapply = function (args) {\n    var deferred = defer();\n    var nodeArgs = array_slice(args);\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided individually, and returns a promise.\n * @example\n * Q.nfcall(FS.readFile, __filename)\n * .then(function (content) {\n * })\n *\n */\nQ.nfcall = function (callback /*...args*/) {\n    var args = array_slice(arguments, 1);\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfcall = function (/*...args*/) {\n    var nodeArgs = array_slice(arguments);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Wraps a NodeJS continuation passing function and returns an equivalent\n * version that returns a promise.\n * @example\n * Q.nfbind(FS.readFile, __filename)(\"utf-8\")\n * .then(console.log)\n * .done()\n */\nQ.nfbind =\nQ.denodeify = function (callback /*...args*/) {\n    var baseArgs = array_slice(arguments, 1);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        Q(callback).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nfbind =\nPromise.prototype.denodeify = function (/*...args*/) {\n    var args = array_slice(arguments);\n    args.unshift(this);\n    return Q.denodeify.apply(void 0, args);\n};\n\nQ.nbind = function (callback, thisp /*...args*/) {\n    var baseArgs = array_slice(arguments, 2);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        function bound() {\n            return callback.apply(thisp, arguments);\n        }\n        Q(bound).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nbind = function (/*thisp, ...args*/) {\n    var args = array_slice(arguments, 0);\n    args.unshift(this);\n    return Q.nbind.apply(void 0, args);\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback with a given array of arguments, plus a provided callback.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param {Array} args arguments to pass to the method; the callback\n * will be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nmapply = // XXX As proposed by \"Redsandro\"\nQ.npost = function (object, name, args) {\n    return Q(object).npost(name, args);\n};\n\nPromise.prototype.nmapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.npost = function (name, args) {\n    var nodeArgs = array_slice(args || []);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback, forwarding the given variadic arguments, plus a provided\n * callback argument.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param ...args arguments to pass to the method; the callback will\n * be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nsend = // XXX Based on Mark Miller's proposed \"send\"\nQ.nmcall = // XXX Based on \"Redsandro's\" proposal\nQ.ninvoke = function (object, name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 2);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    Q(object).dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\nPromise.prototype.nsend = // XXX Based on Mark Miller's proposed \"send\"\nPromise.prototype.nmcall = // XXX Based on \"Redsandro's\" proposal\nPromise.prototype.ninvoke = function (name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 1);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * If a function would like to support both Node continuation-passing-style and\n * promise-returning-style, it can end its internal promise chain with\n * `nodeify(nodeback)`, forwarding the optional nodeback argument.  If the user\n * elects to use a nodeback, the result will be sent there.  If they do not\n * pass a nodeback, they will receive the result promise.\n * @param object a result (or a promise for a result)\n * @param {Function} nodeback a Node.js-style callback\n * @returns either the promise or nothing\n */\nQ.nodeify = nodeify;\nfunction nodeify(object, nodeback) {\n    return Q(object).nodeify(nodeback);\n}\n\nPromise.prototype.nodeify = function (nodeback) {\n    if (nodeback) {\n        this.then(function (value) {\n            Q.nextTick(function () {\n                nodeback(null, value);\n            });\n        }, function (error) {\n            Q.nextTick(function () {\n                nodeback(error);\n            });\n        });\n    } else {\n        return this;\n    }\n};\n\nQ.noConflict = function() {\n    throw new Error(\"Q.noConflict only works when Q is used as a global\");\n};\n\n// All code before this point will be filtered from stack traces.\nvar qEndingLine = captureLine();\n\nreturn Q;\n\n});\n\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/q/q.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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":["// vim:ts=4:sts=4:sw=4:\n/*!\n *\n * Copyright 2009-2012 Kris Kowal under the terms of the MIT\n * license found at http://github.com/kriskowal/q/raw/master/LICENSE\n *\n * With parts by Tyler Close\n * Copyright 2007-2009 Tyler Close under the terms of the MIT X license found\n * at http://www.opensource.org/licenses/mit-license.html\n * Forked at ref_send.js version: 2009-05-11\n *\n * With parts by Mark Miller\n * Copyright (C) 2011 Google Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n */\n\n(function (definition) {\n    \"use strict\";\n\n    // This file will function properly as a <script> tag, or a module\n    // using CommonJS and NodeJS or RequireJS module formats.  In\n    // Common/Node/RequireJS, the module exports the Q API and when\n    // executed as a simple <script>, it creates a Q global instead.\n\n    // Montage Require\n    if (typeof bootstrap === \"function\") {\n        bootstrap(\"promise\", definition);\n\n    // CommonJS\n    } else if (typeof exports === \"object\" && typeof module === \"object\") {\n        module.exports = definition();\n\n    // RequireJS\n    } else if (typeof define === \"function\" && define.amd) {\n        define(definition);\n\n    // SES (Secure EcmaScript)\n    } else if (typeof ses !== \"undefined\") {\n        if (!ses.ok()) {\n            return;\n        } else {\n            ses.makeQ = definition;\n        }\n\n    // <script>\n    } else if (typeof window !== \"undefined\" || typeof self !== \"undefined\") {\n        // Prefer window over self for add-on scripts. Use self for\n        // non-windowed contexts.\n        var global = typeof window !== \"undefined\" ? window : self;\n\n        // Get the `window` object, save the previous Q global\n        // and initialize Q as a global.\n        var previousQ = global.Q;\n        global.Q = definition();\n\n        // Add a noConflict function so Q can be removed from the\n        // global namespace.\n        global.Q.noConflict = function () {\n            global.Q = previousQ;\n            return this;\n        };\n\n    } else {\n        throw new Error(\"This environment was not anticipated by Q. Please file a bug.\");\n    }\n\n})(function () {\n\"use strict\";\n\nvar hasStacks = false;\ntry {\n    throw new Error();\n} catch (e) {\n    hasStacks = !!e.stack;\n}\n\n// All code after this point will be filtered from stack traces reported\n// by Q.\nvar qStartingLine = captureLine();\nvar qFileName;\n\n// shims\n\n// used for fallback in \"allResolved\"\nvar noop = function () {};\n\n// Use the fastest possible means to execute a task in a future turn\n// of the event loop.\nvar nextTick =(function () {\n    // linked list of tasks (single, with head node)\n    var head = {task: void 0, next: null};\n    var tail = head;\n    var flushing = false;\n    var requestTick = void 0;\n    var isNodeJS = false;\n    // queue for late tasks, used by unhandled rejection tracking\n    var laterQueue = [];\n\n    function flush() {\n        /* jshint loopfunc: true */\n        var task, domain;\n\n        while (head.next) {\n            head = head.next;\n            task = head.task;\n            head.task = void 0;\n            domain = head.domain;\n\n            if (domain) {\n                head.domain = void 0;\n                domain.enter();\n            }\n            runSingle(task, domain);\n\n        }\n        while (laterQueue.length) {\n            task = laterQueue.pop();\n            runSingle(task);\n        }\n        flushing = false;\n    }\n    // runs a single function in the async queue\n    function runSingle(task, domain) {\n        try {\n            task();\n\n        } catch (e) {\n            if (isNodeJS) {\n                // In node, uncaught exceptions are considered fatal errors.\n                // Re-throw them synchronously to interrupt flushing!\n\n                // Ensure continuation if the uncaught exception is suppressed\n                // listening \"uncaughtException\" events (as domains does).\n                // Continue in next event to avoid tick recursion.\n                if (domain) {\n                    domain.exit();\n                }\n                setTimeout(flush, 0);\n                if (domain) {\n                    domain.enter();\n                }\n\n                throw e;\n\n            } else {\n                // In browsers, uncaught exceptions are not fatal.\n                // Re-throw them asynchronously to avoid slow-downs.\n                setTimeout(function () {\n                    throw e;\n                }, 0);\n            }\n        }\n\n        if (domain) {\n            domain.exit();\n        }\n    }\n\n    nextTick = function (task) {\n        tail = tail.next = {\n            task: task,\n            domain: isNodeJS && process.domain,\n            next: null\n        };\n\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n\n    if (typeof process === \"object\" &&\n        process.toString() === \"[object process]\" && process.nextTick) {\n        // Ensure Q is in a real Node environment, with a `process.nextTick`.\n        // To see through fake Node environments:\n        // * Mocha test runner - exposes a `process` global without a `nextTick`\n        // * Browserify - exposes a `process.nexTick` function that uses\n        //   `setTimeout`. In this case `setImmediate` is preferred because\n        //    it is faster. Browserify's `process.toString()` yields\n        //   \"[object Object]\", while in a real Node environment\n        //   `process.nextTick()` yields \"[object process]\".\n        isNodeJS = true;\n\n        requestTick = function () {\n            process.nextTick(flush);\n        };\n\n    } else if (typeof setImmediate === \"function\") {\n        // In IE10, Node.js 0.9+, or https://github.com/NobleJS/setImmediate\n        if (typeof window !== \"undefined\") {\n            requestTick = setImmediate.bind(window, flush);\n        } else {\n            requestTick = function () {\n                setImmediate(flush);\n            };\n        }\n\n    } else if (typeof MessageChannel !== \"undefined\") {\n        // modern browsers\n        // http://www.nonblocking.io/2011/06/windownexttick.html\n        var channel = new MessageChannel();\n        // At least Safari Version 6.0.5 (8536.30.1) intermittently cannot create\n        // working message ports the first time a page loads.\n        channel.port1.onmessage = function () {\n            requestTick = requestPortTick;\n            channel.port1.onmessage = flush;\n            flush();\n        };\n        var requestPortTick = function () {\n            // Opera requires us to provide a message payload, regardless of\n            // whether we use it.\n            channel.port2.postMessage(0);\n        };\n        requestTick = function () {\n            setTimeout(flush, 0);\n            requestPortTick();\n        };\n\n    } else {\n        // old browsers\n        requestTick = function () {\n            setTimeout(flush, 0);\n        };\n    }\n    // runs a task after all other tasks have been run\n    // this is useful for unhandled rejection tracking that needs to happen\n    // after all `then`d tasks have been run.\n    nextTick.runAfter = function (task) {\n        laterQueue.push(task);\n        if (!flushing) {\n            flushing = true;\n            requestTick();\n        }\n    };\n    return nextTick;\n})();\n\n// Attempt to make generics safe in the face of downstream\n// modifications.\n// There is no situation where this is necessary.\n// If you need a security guarantee, these primordials need to be\n// deeply frozen anyway, and if you don’t need a security guarantee,\n// this is just plain paranoid.\n// However, this **might** have the nice side-effect of reducing the size of\n// the minified code by reducing x.call() to merely x()\n// See Mark Miller’s explanation of what this does.\n// http://wiki.ecmascript.org/doku.php?id=conventions:safe_meta_programming\nvar call = Function.call;\nfunction uncurryThis(f) {\n    return function () {\n        return call.apply(f, arguments);\n    };\n}\n// This is equivalent, but slower:\n// uncurryThis = Function_bind.bind(Function_bind.call);\n// http://jsperf.com/uncurrythis\n\nvar array_slice = uncurryThis(Array.prototype.slice);\n\nvar array_reduce = uncurryThis(\n    Array.prototype.reduce || function (callback, basis) {\n        var index = 0,\n            length = this.length;\n        // concerning the initial value, if one is not provided\n        if (arguments.length === 1) {\n            // seek to the first value in the array, accounting\n            // for the possibility that is is a sparse array\n            do {\n                if (index in this) {\n                    basis = this[index++];\n                    break;\n                }\n                if (++index >= length) {\n                    throw new TypeError();\n                }\n            } while (1);\n        }\n        // reduce\n        for (; index < length; index++) {\n            // account for the possibility that the array is sparse\n            if (index in this) {\n                basis = callback(basis, this[index], index);\n            }\n        }\n        return basis;\n    }\n);\n\nvar array_indexOf = uncurryThis(\n    Array.prototype.indexOf || function (value) {\n        // not a very good shim, but good enough for our one use of it\n        for (var i = 0; i < this.length; i++) {\n            if (this[i] === value) {\n                return i;\n            }\n        }\n        return -1;\n    }\n);\n\nvar array_map = uncurryThis(\n    Array.prototype.map || function (callback, thisp) {\n        var self = this;\n        var collect = [];\n        array_reduce(self, function (undefined, value, index) {\n            collect.push(callback.call(thisp, value, index, self));\n        }, void 0);\n        return collect;\n    }\n);\n\nvar object_create = Object.create || function (prototype) {\n    function Type() { }\n    Type.prototype = prototype;\n    return new Type();\n};\n\nvar object_hasOwnProperty = uncurryThis(Object.prototype.hasOwnProperty);\n\nvar object_keys = Object.keys || function (object) {\n    var keys = [];\n    for (var key in object) {\n        if (object_hasOwnProperty(object, key)) {\n            keys.push(key);\n        }\n    }\n    return keys;\n};\n\nvar object_toString = uncurryThis(Object.prototype.toString);\n\nfunction isObject(value) {\n    return value === Object(value);\n}\n\n// generator related shims\n\n// FIXME: Remove this function once ES6 generators are in SpiderMonkey.\nfunction isStopIteration(exception) {\n    return (\n        object_toString(exception) === \"[object StopIteration]\" ||\n        exception instanceof QReturnValue\n    );\n}\n\n// FIXME: Remove this helper and Q.return once ES6 generators are in\n// SpiderMonkey.\nvar QReturnValue;\nif (typeof ReturnValue !== \"undefined\") {\n    QReturnValue = ReturnValue;\n} else {\n    QReturnValue = function (value) {\n        this.value = value;\n    };\n}\n\n// long stack traces\n\nvar STACK_JUMP_SEPARATOR = \"From previous event:\";\n\nfunction makeStackTraceLong(error, promise) {\n    // If possible, transform the error stack trace by removing Node and Q\n    // cruft, then concatenating with the stack trace of `promise`. See #57.\n    if (hasStacks &&\n        promise.stack &&\n        typeof error === \"object\" &&\n        error !== null &&\n        error.stack &&\n        error.stack.indexOf(STACK_JUMP_SEPARATOR) === -1\n    ) {\n        var stacks = [];\n        for (var p = promise; !!p; p = p.source) {\n            if (p.stack) {\n                stacks.unshift(p.stack);\n            }\n        }\n        stacks.unshift(error.stack);\n\n        var concatedStacks = stacks.join(\"\\n\" + STACK_JUMP_SEPARATOR + \"\\n\");\n        error.stack = filterStackString(concatedStacks);\n    }\n}\n\nfunction filterStackString(stackString) {\n    var lines = stackString.split(\"\\n\");\n    var desiredLines = [];\n    for (var i = 0; i < lines.length; ++i) {\n        var line = lines[i];\n\n        if (!isInternalFrame(line) && !isNodeFrame(line) && line) {\n            desiredLines.push(line);\n        }\n    }\n    return desiredLines.join(\"\\n\");\n}\n\nfunction isNodeFrame(stackLine) {\n    return stackLine.indexOf(\"(module.js:\") !== -1 ||\n           stackLine.indexOf(\"(node.js:\") !== -1;\n}\n\nfunction getFileNameAndLineNumber(stackLine) {\n    // Named functions: \"at functionName (filename:lineNumber:columnNumber)\"\n    // In IE10 function name can have spaces (\"Anonymous function\") O_o\n    var attempt1 = /at .+ \\((.+):(\\d+):(?:\\d+)\\)$/.exec(stackLine);\n    if (attempt1) {\n        return [attempt1[1], Number(attempt1[2])];\n    }\n\n    // Anonymous functions: \"at filename:lineNumber:columnNumber\"\n    var attempt2 = /at ([^ ]+):(\\d+):(?:\\d+)$/.exec(stackLine);\n    if (attempt2) {\n        return [attempt2[1], Number(attempt2[2])];\n    }\n\n    // Firefox style: \"function@filename:lineNumber or @filename:lineNumber\"\n    var attempt3 = /.*@(.+):(\\d+)$/.exec(stackLine);\n    if (attempt3) {\n        return [attempt3[1], Number(attempt3[2])];\n    }\n}\n\nfunction isInternalFrame(stackLine) {\n    var fileNameAndLineNumber = getFileNameAndLineNumber(stackLine);\n\n    if (!fileNameAndLineNumber) {\n        return false;\n    }\n\n    var fileName = fileNameAndLineNumber[0];\n    var lineNumber = fileNameAndLineNumber[1];\n\n    return fileName === qFileName &&\n        lineNumber >= qStartingLine &&\n        lineNumber <= qEndingLine;\n}\n\n// discover own file name and line number range for filtering stack\n// traces\nfunction captureLine() {\n    if (!hasStacks) {\n        return;\n    }\n\n    try {\n        throw new Error();\n    } catch (e) {\n        var lines = e.stack.split(\"\\n\");\n        var firstLine = lines[0].indexOf(\"@\") > 0 ? lines[1] : lines[2];\n        var fileNameAndLineNumber = getFileNameAndLineNumber(firstLine);\n        if (!fileNameAndLineNumber) {\n            return;\n        }\n\n        qFileName = fileNameAndLineNumber[0];\n        return fileNameAndLineNumber[1];\n    }\n}\n\nfunction deprecate(callback, name, alternative) {\n    return function () {\n        if (typeof console !== \"undefined\" &&\n            typeof console.warn === \"function\") {\n            console.warn(name + \" is deprecated, use \" + alternative +\n                         \" instead.\", new Error(\"\").stack);\n        }\n        return callback.apply(callback, arguments);\n    };\n}\n\n// end of shims\n// beginning of real work\n\n/**\n * Constructs a promise for an immediate reference, passes promises through, or\n * coerces promises from different systems.\n * @param value immediate reference or promise\n */\nfunction Q(value) {\n    // If the object is already a Promise, return it directly.  This enables\n    // the resolve function to both be used to created references from objects,\n    // but to tolerably coerce non-promises to promises.\n    if (value instanceof Promise) {\n        return value;\n    }\n\n    // assimilate thenables\n    if (isPromiseAlike(value)) {\n        return coerce(value);\n    } else {\n        return fulfill(value);\n    }\n}\nQ.resolve = Q;\n\n/**\n * Performs a task in a future turn of the event loop.\n * @param {Function} task\n */\nQ.nextTick = nextTick;\n\n/**\n * Controls whether or not long stack traces will be on\n */\nQ.longStackSupport = false;\n\n// enable long stacks if Q_DEBUG is set\nif (typeof process === \"object\" && process && process.env && process.env.Q_DEBUG) {\n    Q.longStackSupport = true;\n}\n\n/**\n * Constructs a {promise, resolve, reject} object.\n *\n * `resolve` is a callback to invoke with a more resolved value for the\n * promise. To fulfill the promise, invoke `resolve` with any value that is\n * not a thenable. To reject the promise, invoke `resolve` with a rejected\n * thenable, or invoke `reject` with the reason directly. To resolve the\n * promise to another thenable, thus putting it in the same state, invoke\n * `resolve` with that other thenable.\n */\nQ.defer = defer;\nfunction defer() {\n    // if \"messages\" is an \"Array\", that indicates that the promise has not yet\n    // been resolved.  If it is \"undefined\", it has been resolved.  Each\n    // element of the messages array is itself an array of complete arguments to\n    // forward to the resolved promise.  We coerce the resolution value to a\n    // promise using the `resolve` function because it handles both fully\n    // non-thenable values and other thenables gracefully.\n    var messages = [], progressListeners = [], resolvedPromise;\n\n    var deferred = object_create(defer.prototype);\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, operands) {\n        var args = array_slice(arguments);\n        if (messages) {\n            messages.push(args);\n            if (op === \"when\" && operands[1]) { // progress operand\n                progressListeners.push(operands[1]);\n            }\n        } else {\n            Q.nextTick(function () {\n                resolvedPromise.promiseDispatch.apply(resolvedPromise, args);\n            });\n        }\n    };\n\n    // XXX deprecated\n    promise.valueOf = function () {\n        if (messages) {\n            return promise;\n        }\n        var nearerValue = nearer(resolvedPromise);\n        if (isPromise(nearerValue)) {\n            resolvedPromise = nearerValue; // shorten chain\n        }\n        return nearerValue;\n    };\n\n    promise.inspect = function () {\n        if (!resolvedPromise) {\n            return { state: \"pending\" };\n        }\n        return resolvedPromise.inspect();\n    };\n\n    if (Q.longStackSupport && hasStacks) {\n        try {\n            throw new Error();\n        } catch (e) {\n            // NOTE: don't try to use `Error.captureStackTrace` or transfer the\n            // accessor around; that causes memory leaks as per GH-111. Just\n            // reify the stack trace as a string ASAP.\n            //\n            // At the same time, cut off the first line; it's always just\n            // \"[object Promise]\\n\", as per the `toString`.\n            promise.stack = e.stack.substring(e.stack.indexOf(\"\\n\") + 1);\n        }\n    }\n\n    // NOTE: we do the checks for `resolvedPromise` in each method, instead of\n    // consolidating them into `become`, since otherwise we'd create new\n    // promises with the lines `become(whatever(value))`. See e.g. GH-252.\n\n    function become(newPromise) {\n        resolvedPromise = newPromise;\n        promise.source = newPromise;\n\n        array_reduce(messages, function (undefined, message) {\n            Q.nextTick(function () {\n                newPromise.promiseDispatch.apply(newPromise, message);\n            });\n        }, void 0);\n\n        messages = void 0;\n        progressListeners = void 0;\n    }\n\n    deferred.promise = promise;\n    deferred.resolve = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(Q(value));\n    };\n\n    deferred.fulfill = function (value) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(fulfill(value));\n    };\n    deferred.reject = function (reason) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        become(reject(reason));\n    };\n    deferred.notify = function (progress) {\n        if (resolvedPromise) {\n            return;\n        }\n\n        array_reduce(progressListeners, function (undefined, progressListener) {\n            Q.nextTick(function () {\n                progressListener(progress);\n            });\n        }, void 0);\n    };\n\n    return deferred;\n}\n\n/**\n * Creates a Node-style callback that will resolve or reject the deferred\n * promise.\n * @returns a nodeback\n */\ndefer.prototype.makeNodeResolver = function () {\n    var self = this;\n    return function (error, value) {\n        if (error) {\n            self.reject(error);\n        } else if (arguments.length > 2) {\n            self.resolve(array_slice(arguments, 1));\n        } else {\n            self.resolve(value);\n        }\n    };\n};\n\n/**\n * @param resolver {Function} a function that returns nothing and accepts\n * the resolve, reject, and notify functions for a deferred.\n * @returns a promise that may be resolved with the given resolve and reject\n * functions, or rejected by a thrown exception in resolver\n */\nQ.Promise = promise; // ES6\nQ.promise = promise;\nfunction promise(resolver) {\n    if (typeof resolver !== \"function\") {\n        throw new TypeError(\"resolver must be a function.\");\n    }\n    var deferred = defer();\n    try {\n        resolver(deferred.resolve, deferred.reject, deferred.notify);\n    } catch (reason) {\n        deferred.reject(reason);\n    }\n    return deferred.promise;\n}\n\npromise.race = race; // ES6\npromise.all = all; // ES6\npromise.reject = reject; // ES6\npromise.resolve = Q; // ES6\n\n// XXX experimental.  This method is a way to denote that a local value is\n// serializable and should be immediately dispatched to a remote upon request,\n// instead of passing a reference.\nQ.passByCopy = function (object) {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return object;\n};\n\nPromise.prototype.passByCopy = function () {\n    //freeze(object);\n    //passByCopies.set(object, true);\n    return this;\n};\n\n/**\n * If two promises eventually fulfill to the same value, promises that value,\n * but otherwise rejects.\n * @param x {Any*}\n * @param y {Any*}\n * @returns {Any*} a promise for x and y if they are the same, but a rejection\n * otherwise.\n *\n */\nQ.join = function (x, y) {\n    return Q(x).join(y);\n};\n\nPromise.prototype.join = function (that) {\n    return Q([this, that]).spread(function (x, y) {\n        if (x === y) {\n            // TODO: \"===\" should be Object.is or equiv\n            return x;\n        } else {\n            throw new Error(\"Can't join: not the same: \" + x + \" \" + y);\n        }\n    });\n};\n\n/**\n * Returns a promise for the first of an array of promises to become settled.\n * @param answers {Array[Any*]} promises to race\n * @returns {Any*} the first promise to be settled\n */\nQ.race = race;\nfunction race(answerPs) {\n    return promise(function (resolve, reject) {\n        // Switch to this once we can assume at least ES5\n        // answerPs.forEach(function (answerP) {\n        //     Q(answerP).then(resolve, reject);\n        // });\n        // Use this in the meantime\n        for (var i = 0, len = answerPs.length; i < len; i++) {\n            Q(answerPs[i]).then(resolve, reject);\n        }\n    });\n}\n\nPromise.prototype.race = function () {\n    return this.then(Q.race);\n};\n\n/**\n * Constructs a Promise with a promise descriptor object and optional fallback\n * function.  The descriptor contains methods like when(rejected), get(name),\n * set(name, value), post(name, args), and delete(name), which all\n * return either a value, a promise for a value, or a rejection.  The fallback\n * accepts the operation name, a resolver, and any further arguments that would\n * have been forwarded to the appropriate method above had a method been\n * provided with the proper name.  The API makes no guarantees about the nature\n * of the returned object, apart from that it is usable whereever promises are\n * bought and sold.\n */\nQ.makePromise = Promise;\nfunction Promise(descriptor, fallback, inspect) {\n    if (fallback === void 0) {\n        fallback = function (op) {\n            return reject(new Error(\n                \"Promise does not support operation: \" + op\n            ));\n        };\n    }\n    if (inspect === void 0) {\n        inspect = function () {\n            return {state: \"unknown\"};\n        };\n    }\n\n    var promise = object_create(Promise.prototype);\n\n    promise.promiseDispatch = function (resolve, op, args) {\n        var result;\n        try {\n            if (descriptor[op]) {\n                result = descriptor[op].apply(promise, args);\n            } else {\n                result = fallback.call(promise, op, args);\n            }\n        } catch (exception) {\n            result = reject(exception);\n        }\n        if (resolve) {\n            resolve(result);\n        }\n    };\n\n    promise.inspect = inspect;\n\n    // XXX deprecated `valueOf` and `exception` support\n    if (inspect) {\n        var inspected = inspect();\n        if (inspected.state === \"rejected\") {\n            promise.exception = inspected.reason;\n        }\n\n        promise.valueOf = function () {\n            var inspected = inspect();\n            if (inspected.state === \"pending\" ||\n                inspected.state === \"rejected\") {\n                return promise;\n            }\n            return inspected.value;\n        };\n    }\n\n    return promise;\n}\n\nPromise.prototype.toString = function () {\n    return \"[object Promise]\";\n};\n\nPromise.prototype.then = function (fulfilled, rejected, progressed) {\n    var self = this;\n    var deferred = defer();\n    var done = false;   // ensure the untrusted promise makes at most a\n                        // single call to one of the callbacks\n\n    function _fulfilled(value) {\n        try {\n            return typeof fulfilled === \"function\" ? fulfilled(value) : value;\n        } catch (exception) {\n            return reject(exception);\n        }\n    }\n\n    function _rejected(exception) {\n        if (typeof rejected === \"function\") {\n            makeStackTraceLong(exception, self);\n            try {\n                return rejected(exception);\n            } catch (newException) {\n                return reject(newException);\n            }\n        }\n        return reject(exception);\n    }\n\n    function _progressed(value) {\n        return typeof progressed === \"function\" ? progressed(value) : value;\n    }\n\n    Q.nextTick(function () {\n        self.promiseDispatch(function (value) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_fulfilled(value));\n        }, \"when\", [function (exception) {\n            if (done) {\n                return;\n            }\n            done = true;\n\n            deferred.resolve(_rejected(exception));\n        }]);\n    });\n\n    // Progress propagator need to be attached in the current tick.\n    self.promiseDispatch(void 0, \"when\", [void 0, function (value) {\n        var newValue;\n        var threw = false;\n        try {\n            newValue = _progressed(value);\n        } catch (e) {\n            threw = true;\n            if (Q.onerror) {\n                Q.onerror(e);\n            } else {\n                throw e;\n            }\n        }\n\n        if (!threw) {\n            deferred.notify(newValue);\n        }\n    }]);\n\n    return deferred.promise;\n};\n\nQ.tap = function (promise, callback) {\n    return Q(promise).tap(callback);\n};\n\n/**\n * Works almost like \"finally\", but not called for rejections.\n * Original resolution value is passed through callback unaffected.\n * Callback may return a promise that will be awaited for.\n * @param {Function} callback\n * @returns {Q.Promise}\n * @example\n * doSomething()\n *   .then(...)\n *   .tap(console.log)\n *   .then(...);\n */\nPromise.prototype.tap = function (callback) {\n    callback = Q(callback);\n\n    return this.then(function (value) {\n        return callback.fcall(value).thenResolve(value);\n    });\n};\n\n/**\n * Registers an observer on a promise.\n *\n * Guarantees:\n *\n * 1. that fulfilled and rejected will be called only once.\n * 2. that either the fulfilled callback or the rejected callback will be\n *    called, but not both.\n * 3. that fulfilled and rejected will not be called in this turn.\n *\n * @param value      promise or immediate reference to observe\n * @param fulfilled  function to be called with the fulfilled value\n * @param rejected   function to be called with the rejection exception\n * @param progressed function to be called on any progress notifications\n * @return promise for the return value from the invoked callback\n */\nQ.when = when;\nfunction when(value, fulfilled, rejected, progressed) {\n    return Q(value).then(fulfilled, rejected, progressed);\n}\n\nPromise.prototype.thenResolve = function (value) {\n    return this.then(function () { return value; });\n};\n\nQ.thenResolve = function (promise, value) {\n    return Q(promise).thenResolve(value);\n};\n\nPromise.prototype.thenReject = function (reason) {\n    return this.then(function () { throw reason; });\n};\n\nQ.thenReject = function (promise, reason) {\n    return Q(promise).thenReject(reason);\n};\n\n/**\n * If an object is not a promise, it is as \"near\" as possible.\n * If a promise is rejected, it is as \"near\" as possible too.\n * If it’s a fulfilled promise, the fulfillment value is nearer.\n * If it’s a deferred promise and the deferred has been resolved, the\n * resolution is \"nearer\".\n * @param object\n * @returns most resolved (nearest) form of the object\n */\n\n// XXX should we re-do this?\nQ.nearer = nearer;\nfunction nearer(value) {\n    if (isPromise(value)) {\n        var inspected = value.inspect();\n        if (inspected.state === \"fulfilled\") {\n            return inspected.value;\n        }\n    }\n    return value;\n}\n\n/**\n * @returns whether the given object is a promise.\n * Otherwise it is a fulfilled value.\n */\nQ.isPromise = isPromise;\nfunction isPromise(object) {\n    return object instanceof Promise;\n}\n\nQ.isPromiseAlike = isPromiseAlike;\nfunction isPromiseAlike(object) {\n    return isObject(object) && typeof object.then === \"function\";\n}\n\n/**\n * @returns whether the given object is a pending promise, meaning not\n * fulfilled or rejected.\n */\nQ.isPending = isPending;\nfunction isPending(object) {\n    return isPromise(object) && object.inspect().state === \"pending\";\n}\n\nPromise.prototype.isPending = function () {\n    return this.inspect().state === \"pending\";\n};\n\n/**\n * @returns whether the given object is a value or fulfilled\n * promise.\n */\nQ.isFulfilled = isFulfilled;\nfunction isFulfilled(object) {\n    return !isPromise(object) || object.inspect().state === \"fulfilled\";\n}\n\nPromise.prototype.isFulfilled = function () {\n    return this.inspect().state === \"fulfilled\";\n};\n\n/**\n * @returns whether the given object is a rejected promise.\n */\nQ.isRejected = isRejected;\nfunction isRejected(object) {\n    return isPromise(object) && object.inspect().state === \"rejected\";\n}\n\nPromise.prototype.isRejected = function () {\n    return this.inspect().state === \"rejected\";\n};\n\n//// BEGIN UNHANDLED REJECTION TRACKING\n\n// This promise library consumes exceptions thrown in handlers so they can be\n// handled by a subsequent promise.  The exceptions get added to this array when\n// they are created, and removed when they are handled.  Note that in ES6 or\n// shimmed environments, this would naturally be a `Set`.\nvar unhandledReasons = [];\nvar unhandledRejections = [];\nvar reportedUnhandledRejections = [];\nvar trackUnhandledRejections = true;\n\nfunction resetUnhandledRejections() {\n    unhandledReasons.length = 0;\n    unhandledRejections.length = 0;\n\n    if (!trackUnhandledRejections) {\n        trackUnhandledRejections = true;\n    }\n}\n\nfunction trackRejection(promise, reason) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n    if (typeof process === \"object\" && typeof process.emit === \"function\") {\n        Q.nextTick.runAfter(function () {\n            if (array_indexOf(unhandledRejections, promise) !== -1) {\n                process.emit(\"unhandledRejection\", reason, promise);\n                reportedUnhandledRejections.push(promise);\n            }\n        });\n    }\n\n    unhandledRejections.push(promise);\n    if (reason && typeof reason.stack !== \"undefined\") {\n        unhandledReasons.push(reason.stack);\n    } else {\n        unhandledReasons.push(\"(no stack) \" + reason);\n    }\n}\n\nfunction untrackRejection(promise) {\n    if (!trackUnhandledRejections) {\n        return;\n    }\n\n    var at = array_indexOf(unhandledRejections, promise);\n    if (at !== -1) {\n        if (typeof process === \"object\" && typeof process.emit === \"function\") {\n            Q.nextTick.runAfter(function () {\n                var atReport = array_indexOf(reportedUnhandledRejections, promise);\n                if (atReport !== -1) {\n                    process.emit(\"rejectionHandled\", unhandledReasons[at], promise);\n                    reportedUnhandledRejections.splice(atReport, 1);\n                }\n            });\n        }\n        unhandledRejections.splice(at, 1);\n        unhandledReasons.splice(at, 1);\n    }\n}\n\nQ.resetUnhandledRejections = resetUnhandledRejections;\n\nQ.getUnhandledReasons = function () {\n    // Make a copy so that consumers can't interfere with our internal state.\n    return unhandledReasons.slice();\n};\n\nQ.stopUnhandledRejectionTracking = function () {\n    resetUnhandledRejections();\n    trackUnhandledRejections = false;\n};\n\nresetUnhandledRejections();\n\n//// END UNHANDLED REJECTION TRACKING\n\n/**\n * Constructs a rejected promise.\n * @param reason value describing the failure\n */\nQ.reject = reject;\nfunction reject(reason) {\n    var rejection = Promise({\n        \"when\": function (rejected) {\n            // note that the error has been handled\n            if (rejected) {\n                untrackRejection(this);\n            }\n            return rejected ? rejected(reason) : this;\n        }\n    }, function fallback() {\n        return this;\n    }, function inspect() {\n        return { state: \"rejected\", reason: reason };\n    });\n\n    // Note that the reason has not been handled.\n    trackRejection(rejection, reason);\n\n    return rejection;\n}\n\n/**\n * Constructs a fulfilled promise for an immediate reference.\n * @param value immediate reference\n */\nQ.fulfill = fulfill;\nfunction fulfill(value) {\n    return Promise({\n        \"when\": function () {\n            return value;\n        },\n        \"get\": function (name) {\n            return value[name];\n        },\n        \"set\": function (name, rhs) {\n            value[name] = rhs;\n        },\n        \"delete\": function (name) {\n            delete value[name];\n        },\n        \"post\": function (name, args) {\n            // Mark Miller proposes that post with no name should apply a\n            // promised function.\n            if (name === null || name === void 0) {\n                return value.apply(void 0, args);\n            } else {\n                return value[name].apply(value, args);\n            }\n        },\n        \"apply\": function (thisp, args) {\n            return value.apply(thisp, args);\n        },\n        \"keys\": function () {\n            return object_keys(value);\n        }\n    }, void 0, function inspect() {\n        return { state: \"fulfilled\", value: value };\n    });\n}\n\n/**\n * Converts thenables to Q promises.\n * @param promise thenable promise\n * @returns a Q promise\n */\nfunction coerce(promise) {\n    var deferred = defer();\n    Q.nextTick(function () {\n        try {\n            promise.then(deferred.resolve, deferred.reject, deferred.notify);\n        } catch (exception) {\n            deferred.reject(exception);\n        }\n    });\n    return deferred.promise;\n}\n\n/**\n * Annotates an object such that it will never be\n * transferred away from this process over any promise\n * communication channel.\n * @param object\n * @returns promise a wrapping of that object that\n * additionally responds to the \"isDef\" message\n * without a rejection.\n */\nQ.master = master;\nfunction master(object) {\n    return Promise({\n        \"isDef\": function () {}\n    }, function fallback(op, args) {\n        return dispatch(object, op, args);\n    }, function () {\n        return Q(object).inspect();\n    });\n}\n\n/**\n * Spreads the values of a promised array of arguments into the\n * fulfillment callback.\n * @param fulfilled callback that receives variadic arguments from the\n * promised array\n * @param rejected callback that receives the exception if the promise\n * is rejected.\n * @returns a promise for the return value or thrown exception of\n * either callback.\n */\nQ.spread = spread;\nfunction spread(value, fulfilled, rejected) {\n    return Q(value).spread(fulfilled, rejected);\n}\n\nPromise.prototype.spread = function (fulfilled, rejected) {\n    return this.all().then(function (array) {\n        return fulfilled.apply(void 0, array);\n    }, rejected);\n};\n\n/**\n * The async function is a decorator for generator functions, turning\n * them into asynchronous generators.  Although generators are only part\n * of the newest ECMAScript 6 drafts, this code does not cause syntax\n * errors in older engines.  This code should continue to work and will\n * in fact improve over time as the language improves.\n *\n * ES6 generators are currently part of V8 version 3.19 with the\n * --harmony-generators runtime flag enabled.  SpiderMonkey has had them\n * for longer, but under an older Python-inspired form.  This function\n * works on both kinds of generators.\n *\n * Decorates a generator function such that:\n *  - it may yield promises\n *  - execution will continue when that promise is fulfilled\n *  - the value of the yield expression will be the fulfilled value\n *  - it returns a promise for the return value (when the generator\n *    stops iterating)\n *  - the decorated function returns a promise for the return value\n *    of the generator or the first rejected promise among those\n *    yielded.\n *  - if an error is thrown in the generator, it propagates through\n *    every following yield until it is caught, or until it escapes\n *    the generator function altogether, and is translated into a\n *    rejection for the promise returned by the decorated generator.\n */\nQ.async = async;\nfunction async(makeGenerator) {\n    return function () {\n        // when verb is \"send\", arg is a value\n        // when verb is \"throw\", arg is an exception\n        function continuer(verb, arg) {\n            var result;\n\n            // Until V8 3.19 / Chromium 29 is released, SpiderMonkey is the only\n            // engine that has a deployed base of browsers that support generators.\n            // However, SM's generators use the Python-inspired semantics of\n            // outdated ES6 drafts.  We would like to support ES6, but we'd also\n            // like to make it possible to use generators in deployed browsers, so\n            // we also support Python-style generators.  At some point we can remove\n            // this block.\n\n            if (typeof StopIteration === \"undefined\") {\n                // ES6 Generators\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    return reject(exception);\n                }\n                if (result.done) {\n                    return Q(result.value);\n                } else {\n                    return when(result.value, callback, errback);\n                }\n            } else {\n                // SpiderMonkey Generators\n                // FIXME: Remove this case when SM does ES6 generators.\n                try {\n                    result = generator[verb](arg);\n                } catch (exception) {\n                    if (isStopIteration(exception)) {\n                        return Q(exception.value);\n                    } else {\n                        return reject(exception);\n                    }\n                }\n                return when(result, callback, errback);\n            }\n        }\n        var generator = makeGenerator.apply(this, arguments);\n        var callback = continuer.bind(continuer, \"next\");\n        var errback = continuer.bind(continuer, \"throw\");\n        return callback();\n    };\n}\n\n/**\n * The spawn function is a small wrapper around async that immediately\n * calls the generator and also ends the promise chain, so that any\n * unhandled errors are thrown instead of forwarded to the error\n * handler. This is useful because it's extremely common to run\n * generators at the top-level to work with libraries.\n */\nQ.spawn = spawn;\nfunction spawn(makeGenerator) {\n    Q.done(Q.async(makeGenerator)());\n}\n\n// FIXME: Remove this interface once ES6 generators are in SpiderMonkey.\n/**\n * Throws a ReturnValue exception to stop an asynchronous generator.\n *\n * This interface is a stop-gap measure to support generator return\n * values in older Firefox/SpiderMonkey.  In browsers that support ES6\n * generators like Chromium 29, just use \"return\" in your generator\n * functions.\n *\n * @param value the return value for the surrounding generator\n * @throws ReturnValue exception with the value.\n * @example\n * // ES6 style\n * Q.async(function* () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      return foo + bar;\n * })\n * // Older SpiderMonkey style\n * Q.async(function () {\n *      var foo = yield getFooPromise();\n *      var bar = yield getBarPromise();\n *      Q.return(foo + bar);\n * })\n */\nQ[\"return\"] = _return;\nfunction _return(value) {\n    throw new QReturnValue(value);\n}\n\n/**\n * The promised function decorator ensures that any promise arguments\n * are settled and passed as values (`this` is also settled and passed\n * as a value).  It will also ensure that the result of a function is\n * always a promise.\n *\n * @example\n * var add = Q.promised(function (a, b) {\n *     return a + b;\n * });\n * add(Q(a), Q(B));\n *\n * @param {function} callback The function to decorate\n * @returns {function} a function that has been decorated.\n */\nQ.promised = promised;\nfunction promised(callback) {\n    return function () {\n        return spread([this, all(arguments)], function (self, args) {\n            return callback.apply(self, args);\n        });\n    };\n}\n\n/**\n * sends a message to a value in a future turn\n * @param object* the recipient\n * @param op the name of the message operation, e.g., \"when\",\n * @param args further arguments to be forwarded to the operation\n * @returns result {Promise} a promise for the result of the operation\n */\nQ.dispatch = dispatch;\nfunction dispatch(object, op, args) {\n    return Q(object).dispatch(op, args);\n}\n\nPromise.prototype.dispatch = function (op, args) {\n    var self = this;\n    var deferred = defer();\n    Q.nextTick(function () {\n        self.promiseDispatch(deferred.resolve, op, args);\n    });\n    return deferred.promise;\n};\n\n/**\n * Gets the value of a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to get\n * @return promise for the property value\n */\nQ.get = function (object, key) {\n    return Q(object).dispatch(\"get\", [key]);\n};\n\nPromise.prototype.get = function (key) {\n    return this.dispatch(\"get\", [key]);\n};\n\n/**\n * Sets the value of a property in a future turn.\n * @param object    promise or immediate reference for object object\n * @param name      name of property to set\n * @param value     new value of property\n * @return promise for the return value\n */\nQ.set = function (object, key, value) {\n    return Q(object).dispatch(\"set\", [key, value]);\n};\n\nPromise.prototype.set = function (key, value) {\n    return this.dispatch(\"set\", [key, value]);\n};\n\n/**\n * Deletes a property in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of property to delete\n * @return promise for the return value\n */\nQ.del = // XXX legacy\nQ[\"delete\"] = function (object, key) {\n    return Q(object).dispatch(\"delete\", [key]);\n};\n\nPromise.prototype.del = // XXX legacy\nPromise.prototype[\"delete\"] = function (key) {\n    return this.dispatch(\"delete\", [key]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param value     a value to post, typically an array of\n *                  invocation arguments for promises that\n *                  are ultimately backed with `resolve` values,\n *                  as opposed to those backed with URLs\n *                  wherein the posted value can be any\n *                  JSON serializable object.\n * @return promise for the return value\n */\n// bound locally because it is used by other methods\nQ.mapply = // XXX As proposed by \"Redsandro\"\nQ.post = function (object, name, args) {\n    return Q(object).dispatch(\"post\", [name, args]);\n};\n\nPromise.prototype.mapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.post = function (name, args) {\n    return this.dispatch(\"post\", [name, args]);\n};\n\n/**\n * Invokes a method in a future turn.\n * @param object    promise or immediate reference for target object\n * @param name      name of method to invoke\n * @param ...args   array of invocation arguments\n * @return promise for the return value\n */\nQ.send = // XXX Mark Miller's proposed parlance\nQ.mcall = // XXX As proposed by \"Redsandro\"\nQ.invoke = function (object, name /*...args*/) {\n    return Q(object).dispatch(\"post\", [name, array_slice(arguments, 2)]);\n};\n\nPromise.prototype.send = // XXX Mark Miller's proposed parlance\nPromise.prototype.mcall = // XXX As proposed by \"Redsandro\"\nPromise.prototype.invoke = function (name /*...args*/) {\n    return this.dispatch(\"post\", [name, array_slice(arguments, 1)]);\n};\n\n/**\n * Applies the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param args      array of application arguments\n */\nQ.fapply = function (object, args) {\n    return Q(object).dispatch(\"apply\", [void 0, args]);\n};\n\nPromise.prototype.fapply = function (args) {\n    return this.dispatch(\"apply\", [void 0, args]);\n};\n\n/**\n * Calls the promised function in a future turn.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ[\"try\"] =\nQ.fcall = function (object /* ...args*/) {\n    return Q(object).dispatch(\"apply\", [void 0, array_slice(arguments, 1)]);\n};\n\nPromise.prototype.fcall = function (/*...args*/) {\n    return this.dispatch(\"apply\", [void 0, array_slice(arguments)]);\n};\n\n/**\n * Binds the promised function, transforming return values into a fulfilled\n * promise and thrown errors into a rejected one.\n * @param object    promise or immediate reference for target function\n * @param ...args   array of application arguments\n */\nQ.fbind = function (object /*...args*/) {\n    var promise = Q(object);\n    var args = array_slice(arguments, 1);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\nPromise.prototype.fbind = function (/*...args*/) {\n    var promise = this;\n    var args = array_slice(arguments);\n    return function fbound() {\n        return promise.dispatch(\"apply\", [\n            this,\n            args.concat(array_slice(arguments))\n        ]);\n    };\n};\n\n/**\n * Requests the names of the owned properties of a promised\n * object in a future turn.\n * @param object    promise or immediate reference for target object\n * @return promise for the keys of the eventually settled object\n */\nQ.keys = function (object) {\n    return Q(object).dispatch(\"keys\", []);\n};\n\nPromise.prototype.keys = function () {\n    return this.dispatch(\"keys\", []);\n};\n\n/**\n * Turns an array of promises into a promise for an array.  If any of\n * the promises gets rejected, the whole array is rejected immediately.\n * @param {Array*} an array (or promise for an array) of values (or\n * promises for values)\n * @returns a promise for an array of the corresponding values\n */\n// By Mark Miller\n// http://wiki.ecmascript.org/doku.php?id=strawman:concurrency&rev=1308776521#allfulfilled\nQ.all = all;\nfunction all(promises) {\n    return when(promises, function (promises) {\n        var pendingCount = 0;\n        var deferred = defer();\n        array_reduce(promises, function (undefined, promise, index) {\n            var snapshot;\n            if (\n                isPromise(promise) &&\n                (snapshot = promise.inspect()).state === \"fulfilled\"\n            ) {\n                promises[index] = snapshot.value;\n            } else {\n                ++pendingCount;\n                when(\n                    promise,\n                    function (value) {\n                        promises[index] = value;\n                        if (--pendingCount === 0) {\n                            deferred.resolve(promises);\n                        }\n                    },\n                    deferred.reject,\n                    function (progress) {\n                        deferred.notify({ index: index, value: progress });\n                    }\n                );\n            }\n        }, void 0);\n        if (pendingCount === 0) {\n            deferred.resolve(promises);\n        }\n        return deferred.promise;\n    });\n}\n\nPromise.prototype.all = function () {\n    return all(this);\n};\n\n/**\n * Returns the first resolved promise of an array. Prior rejected promises are\n * ignored.  Rejects only if all promises are rejected.\n * @param {Array*} an array containing values or promises for values\n * @returns a promise fulfilled with the value of the first resolved promise,\n * or a rejected promise if all promises are rejected.\n */\nQ.any = any;\n\nfunction any(promises) {\n    if (promises.length === 0) {\n        return Q.resolve();\n    }\n\n    var deferred = Q.defer();\n    var pendingCount = 0;\n    array_reduce(promises, function (prev, current, index) {\n        var promise = promises[index];\n\n        pendingCount++;\n\n        when(promise, onFulfilled, onRejected, onProgress);\n        function onFulfilled(result) {\n            deferred.resolve(result);\n        }\n        function onRejected() {\n            pendingCount--;\n            if (pendingCount === 0) {\n                deferred.reject(new Error(\n                    \"Can't get fulfillment value from any promise, all \" +\n                    \"promises were rejected.\"\n                ));\n            }\n        }\n        function onProgress(progress) {\n            deferred.notify({\n                index: index,\n                value: progress\n            });\n        }\n    }, undefined);\n\n    return deferred.promise;\n}\n\nPromise.prototype.any = function () {\n    return any(this);\n};\n\n/**\n * Waits for all promises to be settled, either fulfilled or\n * rejected.  This is distinct from `all` since that would stop\n * waiting at the first rejection.  The promise returned by\n * `allResolved` will never be rejected.\n * @param promises a promise for an array (or an array) of promises\n * (or values)\n * @return a promise for an array of promises\n */\nQ.allResolved = deprecate(allResolved, \"allResolved\", \"allSettled\");\nfunction allResolved(promises) {\n    return when(promises, function (promises) {\n        promises = array_map(promises, Q);\n        return when(all(array_map(promises, function (promise) {\n            return when(promise, noop, noop);\n        })), function () {\n            return promises;\n        });\n    });\n}\n\nPromise.prototype.allResolved = function () {\n    return allResolved(this);\n};\n\n/**\n * @see Promise#allSettled\n */\nQ.allSettled = allSettled;\nfunction allSettled(promises) {\n    return Q(promises).allSettled();\n}\n\n/**\n * Turns an array of promises into a promise for an array of their states (as\n * returned by `inspect`) when they have all settled.\n * @param {Array[Any*]} values an array (or promise for an array) of values (or\n * promises for values)\n * @returns {Array[State]} an array of states for the respective values.\n */\nPromise.prototype.allSettled = function () {\n    return this.then(function (promises) {\n        return all(array_map(promises, function (promise) {\n            promise = Q(promise);\n            function regardless() {\n                return promise.inspect();\n            }\n            return promise.then(regardless, regardless);\n        }));\n    });\n};\n\n/**\n * Captures the failure of a promise, giving an oportunity to recover\n * with a callback.  If the given promise is fulfilled, the returned\n * promise is fulfilled.\n * @param {Any*} promise for something\n * @param {Function} callback to fulfill the returned promise if the\n * given promise is rejected\n * @returns a promise for the return value of the callback\n */\nQ.fail = // XXX legacy\nQ[\"catch\"] = function (object, rejected) {\n    return Q(object).then(void 0, rejected);\n};\n\nPromise.prototype.fail = // XXX legacy\nPromise.prototype[\"catch\"] = function (rejected) {\n    return this.then(void 0, rejected);\n};\n\n/**\n * Attaches a listener that can respond to progress notifications from a\n * promise's originating deferred. This listener receives the exact arguments\n * passed to ``deferred.notify``.\n * @param {Any*} promise for something\n * @param {Function} callback to receive any progress notifications\n * @returns the given promise, unchanged\n */\nQ.progress = progress;\nfunction progress(object, progressed) {\n    return Q(object).then(void 0, void 0, progressed);\n}\n\nPromise.prototype.progress = function (progressed) {\n    return this.then(void 0, void 0, progressed);\n};\n\n/**\n * Provides an opportunity to observe the settling of a promise,\n * regardless of whether the promise is fulfilled or rejected.  Forwards\n * the resolution to the returned promise when the callback is done.\n * The callback can return a promise to defer completion.\n * @param {Any*} promise\n * @param {Function} callback to observe the resolution of the given\n * promise, takes no arguments.\n * @returns a promise for the resolution of the given promise when\n * ``fin`` is done.\n */\nQ.fin = // XXX legacy\nQ[\"finally\"] = function (object, callback) {\n    return Q(object)[\"finally\"](callback);\n};\n\nPromise.prototype.fin = // XXX legacy\nPromise.prototype[\"finally\"] = function (callback) {\n    callback = Q(callback);\n    return this.then(function (value) {\n        return callback.fcall().then(function () {\n            return value;\n        });\n    }, function (reason) {\n        // TODO attempt to recycle the rejection with \"this\".\n        return callback.fcall().then(function () {\n            throw reason;\n        });\n    });\n};\n\n/**\n * Terminates a chain of promises, forcing rejections to be\n * thrown as exceptions.\n * @param {Any*} promise at the end of a chain of promises\n * @returns nothing\n */\nQ.done = function (object, fulfilled, rejected, progress) {\n    return Q(object).done(fulfilled, rejected, progress);\n};\n\nPromise.prototype.done = function (fulfilled, rejected, progress) {\n    var onUnhandledError = function (error) {\n        // forward to a future turn so that ``when``\n        // does not catch it and turn it into a rejection.\n        Q.nextTick(function () {\n            makeStackTraceLong(error, promise);\n            if (Q.onerror) {\n                Q.onerror(error);\n            } else {\n                throw error;\n            }\n        });\n    };\n\n    // Avoid unnecessary `nextTick`ing via an unnecessary `when`.\n    var promise = fulfilled || rejected || progress ?\n        this.then(fulfilled, rejected, progress) :\n        this;\n\n    if (typeof process === \"object\" && process && process.domain) {\n        onUnhandledError = process.domain.bind(onUnhandledError);\n    }\n\n    promise.then(void 0, onUnhandledError);\n};\n\n/**\n * Causes a promise to be rejected if it does not get fulfilled before\n * some milliseconds time out.\n * @param {Any*} promise\n * @param {Number} milliseconds timeout\n * @param {Any*} custom error message or Error object (optional)\n * @returns a promise for the resolution of the given promise if it is\n * fulfilled before the timeout, otherwise rejected.\n */\nQ.timeout = function (object, ms, error) {\n    return Q(object).timeout(ms, error);\n};\n\nPromise.prototype.timeout = function (ms, error) {\n    var deferred = defer();\n    var timeoutId = setTimeout(function () {\n        if (!error || \"string\" === typeof error) {\n            error = new Error(error || \"Timed out after \" + ms + \" ms\");\n            error.code = \"ETIMEDOUT\";\n        }\n        deferred.reject(error);\n    }, ms);\n\n    this.then(function (value) {\n        clearTimeout(timeoutId);\n        deferred.resolve(value);\n    }, function (exception) {\n        clearTimeout(timeoutId);\n        deferred.reject(exception);\n    }, deferred.notify);\n\n    return deferred.promise;\n};\n\n/**\n * Returns a promise for the given value (or promised value), some\n * milliseconds after it resolved. Passes rejections immediately.\n * @param {Any*} promise\n * @param {Number} milliseconds\n * @returns a promise for the resolution of the given promise after milliseconds\n * time has elapsed since the resolution of the given promise.\n * If the given promise rejects, that is passed immediately.\n */\nQ.delay = function (object, timeout) {\n    if (timeout === void 0) {\n        timeout = object;\n        object = void 0;\n    }\n    return Q(object).delay(timeout);\n};\n\nPromise.prototype.delay = function (timeout) {\n    return this.then(function (value) {\n        var deferred = defer();\n        setTimeout(function () {\n            deferred.resolve(value);\n        }, timeout);\n        return deferred.promise;\n    });\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided as an array, and returns a promise.\n *\n *      Q.nfapply(FS.readFile, [__filename])\n *      .then(function (content) {\n *      })\n *\n */\nQ.nfapply = function (callback, args) {\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfapply = function (args) {\n    var deferred = defer();\n    var nodeArgs = array_slice(args);\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Passes a continuation to a Node function, which is called with the given\n * arguments provided individually, and returns a promise.\n * @example\n * Q.nfcall(FS.readFile, __filename)\n * .then(function (content) {\n * })\n *\n */\nQ.nfcall = function (callback /*...args*/) {\n    var args = array_slice(arguments, 1);\n    return Q(callback).nfapply(args);\n};\n\nPromise.prototype.nfcall = function (/*...args*/) {\n    var nodeArgs = array_slice(arguments);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.fapply(nodeArgs).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Wraps a NodeJS continuation passing function and returns an equivalent\n * version that returns a promise.\n * @example\n * Q.nfbind(FS.readFile, __filename)(\"utf-8\")\n * .then(console.log)\n * .done()\n */\nQ.nfbind =\nQ.denodeify = function (callback /*...args*/) {\n    var baseArgs = array_slice(arguments, 1);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        Q(callback).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nfbind =\nPromise.prototype.denodeify = function (/*...args*/) {\n    var args = array_slice(arguments);\n    args.unshift(this);\n    return Q.denodeify.apply(void 0, args);\n};\n\nQ.nbind = function (callback, thisp /*...args*/) {\n    var baseArgs = array_slice(arguments, 2);\n    return function () {\n        var nodeArgs = baseArgs.concat(array_slice(arguments));\n        var deferred = defer();\n        nodeArgs.push(deferred.makeNodeResolver());\n        function bound() {\n            return callback.apply(thisp, arguments);\n        }\n        Q(bound).fapply(nodeArgs).fail(deferred.reject);\n        return deferred.promise;\n    };\n};\n\nPromise.prototype.nbind = function (/*thisp, ...args*/) {\n    var args = array_slice(arguments, 0);\n    args.unshift(this);\n    return Q.nbind.apply(void 0, args);\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback with a given array of arguments, plus a provided callback.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param {Array} args arguments to pass to the method; the callback\n * will be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nmapply = // XXX As proposed by \"Redsandro\"\nQ.npost = function (object, name, args) {\n    return Q(object).npost(name, args);\n};\n\nPromise.prototype.nmapply = // XXX As proposed by \"Redsandro\"\nPromise.prototype.npost = function (name, args) {\n    var nodeArgs = array_slice(args || []);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * Calls a method of a Node-style object that accepts a Node-style\n * callback, forwarding the given variadic arguments, plus a provided\n * callback argument.\n * @param object an object that has the named method\n * @param {String} name name of the method of object\n * @param ...args arguments to pass to the method; the callback will\n * be provided by Q and appended to these arguments.\n * @returns a promise for the value or error\n */\nQ.nsend = // XXX Based on Mark Miller's proposed \"send\"\nQ.nmcall = // XXX Based on \"Redsandro's\" proposal\nQ.ninvoke = function (object, name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 2);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    Q(object).dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\nPromise.prototype.nsend = // XXX Based on Mark Miller's proposed \"send\"\nPromise.prototype.nmcall = // XXX Based on \"Redsandro's\" proposal\nPromise.prototype.ninvoke = function (name /*...args*/) {\n    var nodeArgs = array_slice(arguments, 1);\n    var deferred = defer();\n    nodeArgs.push(deferred.makeNodeResolver());\n    this.dispatch(\"post\", [name, nodeArgs]).fail(deferred.reject);\n    return deferred.promise;\n};\n\n/**\n * If a function would like to support both Node continuation-passing-style and\n * promise-returning-style, it can end its internal promise chain with\n * `nodeify(nodeback)`, forwarding the optional nodeback argument.  If the user\n * elects to use a nodeback, the result will be sent there.  If they do not\n * pass a nodeback, they will receive the result promise.\n * @param object a result (or a promise for a result)\n * @param {Function} nodeback a Node.js-style callback\n * @returns either the promise or nothing\n */\nQ.nodeify = nodeify;\nfunction nodeify(object, nodeback) {\n    return Q(object).nodeify(nodeback);\n}\n\nPromise.prototype.nodeify = function (nodeback) {\n    if (nodeback) {\n        this.then(function (value) {\n            Q.nextTick(function () {\n                nodeback(null, value);\n            });\n        }, function (error) {\n            Q.nextTick(function () {\n                nodeback(error);\n            });\n        });\n    } else {\n        return this;\n    }\n};\n\nQ.noConflict = function() {\n    throw new Error(\"Q.noConflict only works when Q is used as a global\");\n};\n\n// All code before this point will be filtered from stack traces.\nvar qEndingLine = captureLine();\n\nreturn Q;\n\n});\n"]}","/**\n * Module dependencies.\n */\n\nvar Emitter = require('emitter');\nvar reduce = require('reduce');\n\n/**\n * Root reference for iframes.\n */\n\nvar root;\nif (typeof window !== 'undefined') { // Browser window\n  root = window;\n} else if (typeof self !== 'undefined') { // Web Worker\n  root = self;\n} else { // Other environments\n  root = this;\n}\n\n/**\n * Noop.\n */\n\nfunction noop(){};\n\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * TODO: future proof, move to compoent land\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isHost(obj) {\n  var str = {}.toString.call(obj);\n\n  switch (str) {\n    case '[object File]':\n    case '[object Blob]':\n    case '[object FormData]':\n      return true;\n    default:\n      return false;\n  }\n}\n\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n  if (root.XMLHttpRequest\n      && (!root.location || 'file:' != root.location.protocol\n          || !root.ActiveXObject)) {\n    return new XMLHttpRequest;\n  } else {\n    try { return new ActiveXObject('Microsoft.XMLHTTP'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.6.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.3.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP'); } catch(e) {}\n  }\n  return false;\n};\n\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\nvar trim = ''.trim\n  ? function(s) { return s.trim(); }\n  : function(s) { return s.replace(/(^\\s*|\\s*$)/g, ''); };\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isObject(obj) {\n  return obj === Object(obj);\n}\n\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n  if (!isObject(obj)) return obj;\n  var pairs = [];\n  for (var key in obj) {\n    if (null != obj[key]) {\n      pushEncodedKeyValuePair(pairs, key, obj[key]);\n        }\n      }\n  return pairs.join('&');\n}\n\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n  if (Array.isArray(val)) {\n    return val.forEach(function(v) {\n      pushEncodedKeyValuePair(pairs, key, v);\n    });\n  }\n  pairs.push(encodeURIComponent(key)\n    + '=' + encodeURIComponent(val));\n}\n\n/**\n * Expose serialization method.\n */\n\n request.serializeObject = serialize;\n\n /**\n  * Parse the given x-www-form-urlencoded `str`.\n  *\n  * @param {String} str\n  * @return {Object}\n  * @api private\n  */\n\nfunction parseString(str) {\n  var obj = {};\n  var pairs = str.split('&');\n  var parts;\n  var pair;\n\n  for (var i = 0, len = pairs.length; i < len; ++i) {\n    pair = pairs[i];\n    parts = pair.split('=');\n    obj[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);\n  }\n\n  return obj;\n}\n\n/**\n * Expose parser.\n */\n\nrequest.parseString = parseString;\n\n/**\n * Default MIME type map.\n *\n *     superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n  html: 'text/html',\n  json: 'application/json',\n  xml: 'application/xml',\n  urlencoded: 'application/x-www-form-urlencoded',\n  'form': 'application/x-www-form-urlencoded',\n  'form-data': 'application/x-www-form-urlencoded'\n};\n\n/**\n * Default serialization map.\n *\n *     superagent.serialize['application/xml'] = function(obj){\n *       return 'generated xml here';\n *     };\n *\n */\n\n request.serialize = {\n   'application/x-www-form-urlencoded': serialize,\n   'application/json': JSON.stringify\n };\n\n /**\n  * Default parsers.\n  *\n  *     superagent.parse['application/xml'] = function(str){\n  *       return { object parsed from str };\n  *     };\n  *\n  */\n\nrequest.parse = {\n  'application/x-www-form-urlencoded': parseString,\n  'application/json': JSON.parse\n};\n\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n  var lines = str.split(/\\r?\\n/);\n  var fields = {};\n  var index;\n  var line;\n  var field;\n  var val;\n\n  lines.pop(); // trailing CRLF\n\n  for (var i = 0, len = lines.length; i < len; ++i) {\n    line = lines[i];\n    index = line.indexOf(':');\n    field = line.slice(0, index).toLowerCase();\n    val = trim(line.slice(index + 1));\n    fields[field] = val;\n  }\n\n  return fields;\n}\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction type(str){\n  return str.split(/ *; */).shift();\n};\n\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction params(str){\n  return reduce(str.split(/ *; */), function(obj, str){\n    var parts = str.split(/ *= */)\n      , key = parts.shift()\n      , val = parts.shift();\n\n    if (key && val) obj[key] = val;\n    return obj;\n  }, {});\n};\n\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n *  - set flags (.ok, .error, etc)\n *  - parse header\n *\n * Examples:\n *\n *  Aliasing `superagent` as `request` is nice:\n *\n *      request = superagent;\n *\n *  We can use the promise-like API, or pass callbacks:\n *\n *      request.get('/').end(function(res){});\n *      request.get('/', function(res){});\n *\n *  Sending data can be chained:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' })\n *        .end(function(res){});\n *\n *  Or passed to `.send()`:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' }, function(res){});\n *\n *  Or passed to `.post()`:\n *\n *      request\n *        .post('/user', { name: 'tj' })\n *        .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n *      request\n *        .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\nfunction Response(req, options) {\n  options = options || {};\n  this.req = req;\n  this.xhr = this.req.xhr;\n  // responseText is accessible only if responseType is '' or 'text' and on older browsers\n  this.text = ((this.req.method !='HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text')) || typeof this.xhr.responseType === 'undefined')\n     ? this.xhr.responseText\n     : null;\n  this.statusText = this.req.xhr.statusText;\n  this.setStatusProperties(this.xhr.status);\n  this.header = this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n  // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n  // getResponseHeader still works. so we get content-type even if getting\n  // other headers fails.\n  this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n  this.setHeaderProperties(this.header);\n  this.body = this.req.method != 'HEAD'\n    ? this.parseBody(this.text ? this.text : this.xhr.response)\n    : null;\n}\n\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\nResponse.prototype.get = function(field){\n  return this.header[field.toLowerCase()];\n};\n\n/**\n * Set header related properties:\n *\n *   - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\nResponse.prototype.setHeaderProperties = function(header){\n  // content-type\n  var ct = this.header['content-type'] || '';\n  this.type = type(ct);\n\n  // params\n  var obj = params(ct);\n  for (var key in obj) this[key] = obj[key];\n};\n\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype.parseBody = function(str){\n  var parse = request.parse[this.type];\n  return parse && str && (str.length || str instanceof Object)\n    ? parse(str)\n    : null;\n};\n\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n *   - .noContent\n *   - .badRequest\n *   - .unauthorized\n *   - .notAcceptable\n *   - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\nResponse.prototype.setStatusProperties = function(status){\n  // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n  if (status === 1223) {\n    status = 204;\n  }\n\n  var type = status / 100 | 0;\n\n  // status / class\n  this.status = this.statusCode = status;\n  this.statusType = type;\n\n  // basics\n  this.info = 1 == type;\n  this.ok = 2 == type;\n  this.clientError = 4 == type;\n  this.serverError = 5 == type;\n  this.error = (4 == type || 5 == type)\n    ? this.toError()\n    : false;\n\n  // sugar\n  this.accepted = 202 == status;\n  this.noContent = 204 == status;\n  this.badRequest = 400 == status;\n  this.unauthorized = 401 == status;\n  this.notAcceptable = 406 == status;\n  this.notFound = 404 == status;\n  this.forbidden = 403 == status;\n};\n\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\nResponse.prototype.toError = function(){\n  var req = this.req;\n  var method = req.method;\n  var url = req.url;\n\n  var msg = 'cannot ' + method + ' ' + url + ' (' + this.status + ')';\n  var err = new Error(msg);\n  err.status = this.status;\n  err.method = method;\n  err.url = url;\n\n  return err;\n};\n\n/**\n * Expose `Response`.\n */\n\nrequest.Response = Response;\n\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n  var self = this;\n  Emitter.call(this);\n  this._query = this._query || [];\n  this.method = method;\n  this.url = url;\n  this.header = {};\n  this._header = {};\n  this.on('end', function(){\n    var err = null;\n    var res = null;\n\n    try {\n      res = new Response(self);\n    } catch(e) {\n      err = new Error('Parser is unable to parse the response');\n      err.parse = true;\n      err.original = e;\n      return self.callback(err);\n    }\n\n    self.emit('response', res);\n\n    if (err) {\n      return self.callback(err, res);\n    }\n\n    if (res.status >= 200 && res.status < 300) {\n      return self.callback(err, res);\n    }\n\n    var new_err = new Error(res.statusText || 'Unsuccessful HTTP response');\n    new_err.original = err;\n    new_err.response = res;\n    new_err.status = res.status;\n\n    self.callback(new_err, res);\n  });\n}\n\n/**\n * Mixin `Emitter`.\n */\n\nEmitter(Request.prototype);\n\n/**\n * Allow for extension\n */\n\nRequest.prototype.use = function(fn) {\n  fn(this);\n  return this;\n}\n\n/**\n * Set timeout to `ms`.\n *\n * @param {Number} ms\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.timeout = function(ms){\n  this._timeout = ms;\n  return this;\n};\n\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.clearTimeout = function(){\n  this._timeout = 0;\n  clearTimeout(this._timer);\n  return this;\n};\n\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request}\n * @api public\n */\n\nRequest.prototype.abort = function(){\n  if (this.aborted) return;\n  this.aborted = true;\n  this.xhr.abort();\n  this.clearTimeout();\n  this.emit('abort');\n  return this;\n};\n\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n *\n * Examples:\n *\n *      req.get('/')\n *        .set('Accept', 'application/json')\n *        .set('X-API-Key', 'foobar')\n *        .end(callback);\n *\n *      req.get('/')\n *        .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n *        .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.set = function(field, val){\n  if (isObject(field)) {\n    for (var key in field) {\n      this.set(key, field[key]);\n    }\n    return this;\n  }\n  this._header[field.toLowerCase()] = val;\n  this.header[field] = val;\n  return this;\n};\n\n/**\n * Remove header `field`.\n *\n * Example:\n *\n *      req.get('/')\n *        .unset('User-Agent')\n *        .end(callback);\n *\n * @param {String} field\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.unset = function(field){\n  delete this._header[field.toLowerCase()];\n  delete this.header[field];\n  return this;\n};\n\n/**\n * Get case-insensitive header `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api private\n */\n\nRequest.prototype.getHeader = function(field){\n  return this._header[field.toLowerCase()];\n};\n\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.xml = 'application/xml';\n *\n *      request.post('/')\n *        .type('xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n *      request.post('/')\n *        .type('application/xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function(type){\n  this.set('Content-Type', request.types[type] || type);\n  return this;\n};\n\n/**\n * Force given parser\n *\n * Sets the body parser no matter type.\n *\n * @param {Function}\n * @api public\n */\n\nRequest.prototype.parse = function(fn){\n  this._parser = fn;\n  return this;\n};\n\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.json = 'application/json';\n *\n *      request.get('/agent')\n *        .accept('json')\n *        .end(callback);\n *\n *      request.get('/agent')\n *        .accept('application/json')\n *        .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.accept = function(type){\n  this.set('Accept', request.types[type] || type);\n  return this;\n};\n\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} pass\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.auth = function(user, pass){\n  var str = btoa(user + ':' + pass);\n  this.set('Authorization', 'Basic ' + str);\n  return this;\n};\n\n/**\n* Add query-string `val`.\n*\n* Examples:\n*\n*   request.get('/shoes')\n*     .query('size=10')\n*     .query({ color: 'blue' })\n*\n* @param {Object|String} val\n* @return {Request} for chaining\n* @api public\n*/\n\nRequest.prototype.query = function(val){\n  if ('string' != typeof val) val = serialize(val);\n  if (val) this._query.push(val);\n  return this;\n};\n\n/**\n * Write the field `name` and `val` for \"multipart/form-data\"\n * request bodies.\n *\n * ``` js\n * request.post('/upload')\n *   .field('foo', 'bar')\n *   .end(callback);\n * ```\n *\n * @param {String} name\n * @param {String|Blob|File} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.field = function(name, val){\n  if (!this._formData) this._formData = new root.FormData();\n  this._formData.append(name, val);\n  return this;\n};\n\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `filename`.\n *\n * ``` js\n * request.post('/upload')\n *   .attach(new Blob(['<a id=\"a\"><b id=\"b\">hey!</b></a>'], { type: \"text/html\"}))\n *   .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String} filename\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.attach = function(field, file, filename){\n  if (!this._formData) this._formData = new root.FormData();\n  this._formData.append(field, file, filename);\n  return this;\n};\n\n/**\n * Send `data`, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n *       // querystring\n *       request.get('/search')\n *         .end(callback)\n *\n *       // multiple data \"writes\"\n *       request.get('/search')\n *         .send({ search: 'query' })\n *         .send({ range: '1..5' })\n *         .send({ order: 'desc' })\n *         .end(callback)\n *\n *       // manual json\n *       request.post('/user')\n *         .type('json')\n *         .send('{\"name\":\"tj\"}')\n *         .end(callback)\n *\n *       // auto json\n *       request.post('/user')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // manual x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send('name=tj')\n *         .end(callback)\n *\n *       // auto x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // defaults to x-www-form-urlencoded\n  *      request.post('/user')\n  *        .send('name=tobi')\n  *        .send('species=ferret')\n  *        .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.send = function(data){\n  var obj = isObject(data);\n  var type = this.getHeader('Content-Type');\n\n  // merge\n  if (obj && isObject(this._data)) {\n    for (var key in data) {\n      this._data[key] = data[key];\n    }\n  } else if ('string' == typeof data) {\n    if (!type) this.type('form');\n    type = this.getHeader('Content-Type');\n    if ('application/x-www-form-urlencoded' == type) {\n      this._data = this._data\n        ? this._data + '&' + data\n        : data;\n    } else {\n      this._data = (this._data || '') + data;\n    }\n  } else {\n    this._data = data;\n  }\n\n  if (!obj || isHost(data)) return this;\n  if (!type) this.type('json');\n  return this;\n};\n\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\nRequest.prototype.callback = function(err, res){\n  var fn = this._callback;\n  this.clearTimeout();\n  fn(err, res);\n};\n\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\nRequest.prototype.crossDomainError = function(){\n  var err = new Error('Origin is not allowed by Access-Control-Allow-Origin');\n  err.crossDomain = true;\n  this.callback(err);\n};\n\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\nRequest.prototype.timeoutError = function(){\n  var timeout = this._timeout;\n  var err = new Error('timeout of ' + timeout + 'ms exceeded');\n  err.timeout = timeout;\n  this.callback(err);\n};\n\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\nRequest.prototype.withCredentials = function(){\n  this._withCredentials = true;\n  return this;\n};\n\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.end = function(fn){\n  var self = this;\n  var xhr = this.xhr = request.getXHR();\n  var query = this._query.join('&');\n  var timeout = this._timeout;\n  var data = this._formData || this._data;\n\n  // store callback\n  this._callback = fn || noop;\n\n  // state change\n  xhr.onreadystatechange = function(){\n    if (4 != xhr.readyState) return;\n\n    // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n    // result in the error \"Could not complete the operation due to error c00c023f\"\n    var status;\n    try { status = xhr.status } catch(e) { status = 0; }\n\n    if (0 == status) {\n      if (self.timedout) return self.timeoutError();\n      if (self.aborted) return;\n      return self.crossDomainError();\n    }\n    self.emit('end');\n  };\n\n  // progress\n  var handleProgress = function(e){\n    if (e.total > 0) {\n      e.percent = e.loaded / e.total * 100;\n    }\n    self.emit('progress', e);\n  };\n  if (this.hasListeners('progress')) {\n    xhr.onprogress = handleProgress;\n  }\n  try {\n    if (xhr.upload && this.hasListeners('progress')) {\n      xhr.upload.onprogress = handleProgress;\n    }\n  } catch(e) {\n    // Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n    // Reported here:\n    // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n  }\n\n  // timeout\n  if (timeout && !this._timer) {\n    this._timer = setTimeout(function(){\n      self.timedout = true;\n      self.abort();\n    }, timeout);\n  }\n\n  // querystring\n  if (query) {\n    query = request.serializeObject(query);\n    this.url += ~this.url.indexOf('?')\n      ? '&' + query\n      : '?' + query;\n  }\n\n  // initiate request\n  xhr.open(this.method, this.url, true);\n\n  // CORS\n  if (this._withCredentials) xhr.withCredentials = true;\n\n  // body\n  if ('GET' != this.method && 'HEAD' != this.method && 'string' != typeof data && !isHost(data)) {\n    // serialize stuff\n    var contentType = this.getHeader('Content-Type');\n    var serialize = this._parser || request.serialize[contentType ? contentType.split(';')[0] : ''];\n    if (serialize) data = serialize(data);\n  }\n\n  // set header fields\n  for (var field in this.header) {\n    if (null == this.header[field]) continue;\n    xhr.setRequestHeader(field, this.header[field]);\n  }\n\n  // send stuff\n  this.emit('request', this);\n\n  // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n  // We need null here if data is undefined\n  xhr.send(typeof data !== 'undefined' ? data : null);\n  return this;\n};\n\n/**\n * Faux promise support\n *\n * @param {Function} fulfill\n * @param {Function} reject\n * @return {Request}\n */\n\nRequest.prototype.then = function (fulfill, reject) {\n  return this.end(function(err, res) {\n    err ? reject(err) : fulfill(res);\n  });\n}\n\n/**\n * Expose `Request`.\n */\n\nrequest.Request = Request;\n\n/**\n * Issue a request:\n *\n * Examples:\n *\n *    request('GET', '/users').end(callback)\n *    request('/users').end(callback)\n *    request('/users', callback)\n *\n * @param {String} method\n * @param {String|Function} url or callback\n * @return {Request}\n * @api public\n */\n\nfunction request(method, url) {\n  // callback\n  if ('function' == typeof url) {\n    return new Request('GET', method).end(url);\n  }\n\n  // url first\n  if (1 == arguments.length) {\n    return new Request('GET', method);\n  }\n\n  return new Request(method, url);\n}\n\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.get = function(url, data, fn){\n  var req = request('GET', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.query(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.head = function(url, data, fn){\n  var req = request('HEAD', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * DELETE `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nfunction del(url, fn){\n  var req = request('DELETE', url);\n  if (fn) req.end(fn);\n  return req;\n};\n\nrequest.del = del;\nrequest.delete = del;\n\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function(url, data, fn){\n  var req = request('PATCH', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.post = function(url, data, fn){\n  var req = request('POST', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.put = function(url, data, fn){\n  var req = request('PUT', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * Expose `request`.\n */\n\nmodule.exports = request;\n","\n/**\n * Expose `Emitter`.\n */\n\nmodule.exports = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n  if (obj) return mixin(obj);\n};\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n  for (var key in Emitter.prototype) {\n    obj[key] = Emitter.prototype[key];\n  }\n  return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n  (this._callbacks[event] = this._callbacks[event] || [])\n    .push(fn);\n  return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n  var self = this;\n  this._callbacks = this._callbacks || {};\n\n  function on() {\n    self.off(event, on);\n    fn.apply(this, arguments);\n  }\n\n  on.fn = fn;\n  this.on(event, on);\n  return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n\n  // all\n  if (0 == arguments.length) {\n    this._callbacks = {};\n    return this;\n  }\n\n  // specific event\n  var callbacks = this._callbacks[event];\n  if (!callbacks) return this;\n\n  // remove all handlers\n  if (1 == arguments.length) {\n    delete this._callbacks[event];\n    return this;\n  }\n\n  // remove specific handler\n  var cb;\n  for (var i = 0; i < callbacks.length; i++) {\n    cb = callbacks[i];\n    if (cb === fn || cb.fn === fn) {\n      callbacks.splice(i, 1);\n      break;\n    }\n  }\n  return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n  this._callbacks = this._callbacks || {};\n  var args = [].slice.call(arguments, 1)\n    , callbacks = this._callbacks[event];\n\n  if (callbacks) {\n    callbacks = callbacks.slice(0);\n    for (var i = 0, len = callbacks.length; i < len; ++i) {\n      callbacks[i].apply(this, args);\n    }\n  }\n\n  return this;\n};\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n  this._callbacks = this._callbacks || {};\n  return this._callbacks[event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n  return !! this.listeners(event).length;\n};\n","\n/**\n * Reduce `arr` with `fn`.\n *\n * @param {Array} arr\n * @param {Function} fn\n * @param {Mixed} initial\n *\n * TODO: combatible error handling?\n */\n\nmodule.exports = function(arr, fn, initial){  \n  var idx = 0;\n  var len = arr.length;\n  var curr = arguments.length == 3\n    ? initial\n    : arr[idx++];\n\n  while (idx < len) {\n    curr = fn.call(null, curr, arr[idx], ++idx, arr);\n  }\n  \n  return curr;\n};"]} 24619 24620 /*global JSONEditor*/ 24621 'use strict'; 24622 24623 window.SwaggerUi = Backbone.Router.extend({ 24624 24625 dom_id: 'swagger_ui', 24626 24627 // Attributes 24628 options: null, 24629 api: null, 24630 headerView: null, 24631 mainView: null, 24632 24633 // SwaggerUi accepts all the same options as SwaggerApi 24634 initialize: function(options) { 24635 options = options || {}; 24636 24637 if (options.defaultModelRendering !== 'model') { 24638 options.defaultModelRendering = 'schema'; 24639 } 24640 24641 if (!options.highlightSizeThreshold) { 24642 options.highlightSizeThreshold = 100000; 24643 } 24644 24645 // Allow dom_id to be overridden 24646 if (options.dom_id) { 24647 this.dom_id = options.dom_id; 24648 delete options.dom_id; 24649 } 24650 24651 if (!options.supportedSubmitMethods){ 24652 options.supportedSubmitMethods = [ 24653 'get', 24654 'put', 24655 'post', 24656 'delete', 24657 'head', 24658 'options', 24659 'patch' 24660 ]; 24661 } 24662 24663 if (typeof options.oauth2RedirectUrl === 'string') { 24664 window.oAuthRedirectUrl = options.redirectUrl; 24665 } 24666 24667 // Create an empty div which contains the dom_id 24668 if (! $('#' + this.dom_id).length){ 24669 $('body').append('<div id="' + this.dom_id + '"></div>') ; 24670 } 24671 24672 this.options = options; 24673 24674 // set marked options 24675 marked.setOptions({gfm: true}); 24676 24677 // Set the callbacks 24678 var that = this; 24679 this.options.success = function() { return that.render(); }; 24680 this.options.progress = function(d) { return that.showMessage(d); }; 24681 this.options.failure = function(d) { return that.onLoadFailure(d); }; 24682 24683 // Create view to handle the header inputs 24684 this.headerView = new SwaggerUi.Views.HeaderView({el: $('#header')}); 24685 24686 // Event handler for when the baseUrl/apiKey is entered by user 24687 this.headerView.on('update-swagger-ui', function(data) { 24688 return that.updateSwaggerUi(data); 24689 }); 24690 24691 // JSon Editor custom theming 24692 JSONEditor.defaults.iconlibs.swagger = JSONEditor.AbstractIconLib.extend({ 24693 mapping: { 24694 collapse: 'collapse', 24695 expand: 'expand' 24696 }, 24697 icon_prefix: 'swagger-' 24698 }); 24699 24700 }, 24701 24702 // Set an option after initializing 24703 setOption: function(option, value) { 24704 this.options[option] = value; 24705 }, 24706 24707 // Get the value of a previously set option 24708 getOption: function(option) { 24709 return this.options[option]; 24710 }, 24711 24712 // Event handler for when url/key is received from user 24713 updateSwaggerUi: function(data){ 24714 this.options.url = data.url; 24715 this.load(); 24716 }, 24717 24718 // Create an api and render 24719 load: function(){ 24720 // Initialize the API object 24721 if (this.mainView) { 24722 this.mainView.clear(); 24723 } 24724 var url = this.options.url; 24725 if (url && url.indexOf('http') !== 0) { 24726 url = this.buildUrl(window.location.href.toString(), url); 24727 } 24728 if(this.api) { 24729 this.options.authorizations = this.api.clientAuthorizations.authz; 24730 } 24731 this.options.url = url; 24732 this.headerView.update(url); 24733 24734 this.api = new SwaggerClient(this.options); 24735 }, 24736 24737 // collapse all sections 24738 collapseAll: function(){ 24739 Docs.collapseEndpointListForResource(''); 24740 }, 24741 24742 // list operations for all sections 24743 listAll: function(){ 24744 Docs.collapseOperationsForResource(''); 24745 }, 24746 24747 // expand operations for all sections 24748 expandAll: function(){ 24749 Docs.expandOperationsForResource(''); 24750 }, 24751 24752 // This is bound to success handler for SwaggerApi 24753 // so it gets called when SwaggerApi completes loading 24754 render: function(){ 24755 this.showMessage('Finished Loading Resource Information. Rendering Swagger UI...'); 24756 this.mainView = new SwaggerUi.Views.MainView({ 24757 model: this.api, 24758 el: $('#' + this.dom_id), 24759 swaggerOptions: this.options, 24760 router: this 24761 }).render(); 24762 this.showMessage(); 24763 switch (this.options.docExpansion) { 24764 case 'full': 24765 this.expandAll(); break; 24766 case 'list': 24767 this.listAll(); break; 24768 default: 24769 break; 24770 } 24771 this.renderGFM(); 24772 24773 if (this.options.onComplete){ 24774 this.options.onComplete(this.api, this); 24775 } 24776 24777 setTimeout(Docs.shebang.bind(this), 100); 24778 }, 24779 24780 buildUrl: function(base, url){ 24781 if (url.indexOf('/') === 0) { 24782 var parts = base.split('/'); 24783 base = parts[0] + '//' + parts[2]; 24784 return base + url; 24785 } else { 24786 var endOfPath = base.length; 24787 24788 if (base.indexOf('?') > -1){ 24789 endOfPath = Math.min(endOfPath, base.indexOf('?')); 24790 } 24791 24792 if (base.indexOf('#') > -1){ 24793 endOfPath = Math.min(endOfPath, base.indexOf('#')); 24794 } 24795 24796 base = base.substring(0, endOfPath); 24797 24798 if (base.indexOf('/', base.length - 1 ) !== -1){ 24799 return base + url; 24800 } 24801 24802 return base + '/' + url; 24803 } 24804 }, 24805 24806 // Shows message on topbar of the ui 24807 showMessage: function(data){ 24808 if (data === undefined) { 24809 data = ''; 24810 } 24811 var $msgbar = $('#message-bar'); 24812 $msgbar.removeClass('message-fail'); 24813 $msgbar.addClass('message-success'); 24814 $msgbar.text(data); 24815 if(window.SwaggerTranslator) { 24816 window.SwaggerTranslator.translate($msgbar); 24817 } 24818 }, 24819 24820 // shows message in red 24821 onLoadFailure: function(data){ 24822 if (data === undefined) { 24823 data = ''; 24824 } 24825 $('#message-bar').removeClass('message-success'); 24826 $('#message-bar').addClass('message-fail'); 24827 24828 var val = $('#message-bar').text(data); 24829 24830 if (this.options.onFailure) { 24831 this.options.onFailure(data); 24832 } 24833 24834 return val; 24835 }, 24836 24837 // Renders GFM for elements with 'markdown' class 24838 renderGFM: function(){ 24839 $('.markdown').each(function(){ 24840 $(this).html(marked($(this).html())); 24841 }); 24842 24843 $('.propDesc', '.model-signature .description').each(function () { 24844 $(this).html(marked($(this).html())).addClass('markdown'); 24845 }); 24846 } 24847 24848 }); 24849 24850 window.SwaggerUi.Views = {}; 24851 24852 // don't break backward compatibility with previous versions and warn users to upgrade their code 24853 (function(){ 24854 window.authorizations = { 24855 add: function() { 24856 warn('Using window.authorizations is deprecated. Please use SwaggerUi.api.clientAuthorizations.add().'); 24857 24858 if (typeof window.swaggerUi === 'undefined') { 24859 throw new TypeError('window.swaggerUi is not defined'); 24860 } 24861 24862 if (window.swaggerUi instanceof SwaggerUi) { 24863 window.swaggerUi.api.clientAuthorizations.add.apply(window.swaggerUi.api.clientAuthorizations, arguments); 24864 } 24865 } 24866 }; 24867 24868 window.ApiKeyAuthorization = function() { 24869 warn('window.ApiKeyAuthorization is deprecated. Please use SwaggerClient.ApiKeyAuthorization.'); 24870 SwaggerClient.ApiKeyAuthorization.apply(window, arguments); 24871 }; 24872 24873 window.PasswordAuthorization = function() { 24874 warn('window.PasswordAuthorization is deprecated. Please use SwaggerClient.PasswordAuthorization.'); 24875 SwaggerClient.PasswordAuthorization.apply(window, arguments); 24876 }; 24877 24878 function warn(message) { 24879 if ('console' in window && typeof window.console.warn === 'function') { 24880 console.warn(message); 24881 } 24882 } 24883 })(); 24884 24885 24886 // UMD 24887 (function (root, factory) { 24888 if (typeof define === 'function' && define.amd) { 24889 // AMD. Register as an anonymous module. 24890 define(['b'], function (b) { 24891 return (root.SwaggerUi = factory(b)); 24892 }); 24893 } else if (typeof exports === 'object') { 24894 // Node. Does not work with strict CommonJS, but 24895 // only CommonJS-like environments that support module.exports, 24896 // like Node. 24897 module.exports = factory(require('b')); 24898 } else { 24899 // Browser globals 24900 root.SwaggerUi = factory(root.b); 24901 } 24902 }(this, function () { 24903 return SwaggerUi; 24904 })); 24905 24906 'use strict'; 24907 24908 SwaggerUi.Views.ApiKeyButton = Backbone.View.extend({ // TODO: append this to global SwaggerUi 24909 24910 events:{ 24911 'click #apikey_button' : 'toggleApiKeyContainer', 24912 'click #apply_api_key' : 'applyApiKey' 24913 }, 24914 24915 initialize: function(opts){ 24916 this.options = opts || {}; 24917 this.router = this.options.router; 24918 }, 24919 24920 render: function(){ 24921 var template = this.template(); 24922 $(this.el).html(template(this.model)); 24923 24924 return this; 24925 }, 24926 24927 24928 applyApiKey: function(){ 24929 var keyAuth = new SwaggerClient.ApiKeyAuthorization( 24930 this.model.name, 24931 $('#input_apiKey_entry').val(), 24932 this.model.in 24933 ); 24934 this.router.api.clientAuthorizations.add(this.model.name, keyAuth); 24935 this.router.load(); 24936 $('#apikey_container').show(); 24937 }, 24938 24939 toggleApiKeyContainer: function(){ 24940 if ($('#apikey_container').length) { 24941 24942 var elem = $('#apikey_container').first(); 24943 24944 if (elem.is(':visible')){ 24945 elem.hide(); 24946 } else { 24947 24948 // hide others 24949 $('.auth_container').hide(); 24950 elem.show(); 24951 } 24952 } 24953 }, 24954 24955 template: function(){ 24956 return Handlebars.templates.apikey_button_view; 24957 } 24958 24959 }); 24960 'use strict'; 24961 24962 SwaggerUi.Views.BasicAuthButton = Backbone.View.extend({ 24963 24964 24965 initialize: function (opts) { 24966 this.options = opts || {}; 24967 this.router = this.options.router; 24968 }, 24969 24970 render: function(){ 24971 var template = this.template(); 24972 $(this.el).html(template(this.model)); 24973 24974 return this; 24975 }, 24976 24977 events: { 24978 'click #basic_auth_button' : 'togglePasswordContainer', 24979 'click #apply_basic_auth' : 'applyPassword' 24980 }, 24981 24982 applyPassword: function(event){ 24983 event.preventDefault(); 24984 var username = $('#input_username').val(); 24985 var password = $('#input_password').val(); 24986 var basicAuth = new SwaggerClient.PasswordAuthorization('basic', username, password); 24987 this.router.api.clientAuthorizations.add(this.model.type, basicAuth); 24988 this.router.load(); 24989 $('#basic_auth_container').hide(); 24990 }, 24991 24992 togglePasswordContainer: function(){ 24993 if ($('#basic_auth_container').length) { 24994 var elem = $('#basic_auth_container').show(); 24995 if (elem.is(':visible')){ 24996 elem.slideUp(); 24997 } else { 24998 // hide others 24999 $('.auth_container').hide(); 25000 elem.show(); 25001 } 25002 } 25003 }, 25004 25005 template: function(){ 25006 return Handlebars.templates.basic_auth_button_view; 25007 } 25008 25009 }); 25010 'use strict'; 25011 25012 SwaggerUi.Views.ContentTypeView = Backbone.View.extend({ 25013 initialize: function() {}, 25014 25015 render: function(){ 25016 this.model.contentTypeId = 'ct' + Math.random(); 25017 $(this.el).html(Handlebars.templates.content_type(this.model)); 25018 return this; 25019 } 25020 }); 25021 'use strict'; 25022 25023 SwaggerUi.Views.HeaderView = Backbone.View.extend({ 25024 events: { 25025 'click #show-pet-store-icon' : 'showPetStore', 25026 'click #explore' : 'showCustom', 25027 'keyup #input_baseUrl' : 'showCustomOnKeyup', 25028 'keyup #input_apiKey' : 'showCustomOnKeyup' 25029 }, 25030 25031 initialize: function(){}, 25032 25033 showPetStore: function(){ 25034 this.trigger('update-swagger-ui', { 25035 url:'http://petstore.swagger.io/v2/swagger.json' 25036 }); 25037 }, 25038 25039 showCustomOnKeyup: function(e){ 25040 if (e.keyCode === 13) { 25041 this.showCustom(); 25042 } 25043 }, 25044 25045 showCustom: function(e){ 25046 if (e) { 25047 e.preventDefault(); 25048 } 25049 25050 this.trigger('update-swagger-ui', { 25051 url: $('#input_baseUrl').val(), 25052 apiKey: $('#input_apiKey').val() 25053 }); 25054 }, 25055 25056 update: function(url, apiKey, trigger){ 25057 if (trigger === undefined) { 25058 trigger = false; 25059 } 25060 25061 $('#input_baseUrl').val(url); 25062 25063 //$('#input_apiKey').val(apiKey); 25064 if (trigger) { 25065 this.trigger('update-swagger-ui', {url:url}); 25066 } 25067 } 25068 }); 25069 25070 'use strict'; 25071 25072 SwaggerUi.Views.MainView = Backbone.View.extend({ 25073 apisSorter : { 25074 alpha : function(a,b){ return a.name.localeCompare(b.name); } 25075 }, 25076 operationsSorters : { 25077 alpha : function(a,b){ return a.path.localeCompare(b.path); }, 25078 method : function(a,b){ return a.method.localeCompare(b.method); } 25079 }, 25080 initialize: function(opts){ 25081 var sorterOption, sorterFn, key, value; 25082 opts = opts || {}; 25083 25084 this.router = opts.router; 25085 25086 // Sort APIs 25087 if (opts.swaggerOptions.apisSorter) { 25088 sorterOption = opts.swaggerOptions.apisSorter; 25089 if (_.isFunction(sorterOption)) { 25090 sorterFn = sorterOption; 25091 } else { 25092 sorterFn = this.apisSorter[sorterOption]; 25093 } 25094 if (_.isFunction(sorterFn)) { 25095 this.model.apisArray.sort(sorterFn); 25096 } 25097 } 25098 // Sort operations of each API 25099 if (opts.swaggerOptions.operationsSorter) { 25100 sorterOption = opts.swaggerOptions.operationsSorter; 25101 if (_.isFunction(sorterOption)) { 25102 sorterFn = sorterOption; 25103 } else { 25104 sorterFn = this.operationsSorters[sorterOption]; 25105 } 25106 if (_.isFunction(sorterFn)) { 25107 for (key in this.model.apisArray) { 25108 this.model.apisArray[key].operationsArray.sort(sorterFn); 25109 } 25110 } 25111 } 25112 25113 // set up the UI for input 25114 this.model.auths = []; 25115 25116 for (key in this.model.securityDefinitions) { 25117 value = this.model.securityDefinitions[key]; 25118 25119 this.model.auths.push({ 25120 name: key, 25121 type: value.type, 25122 value: value 25123 }); 25124 } 25125 25126 if ('validatorUrl' in opts.swaggerOptions) { 25127 // Validator URL specified explicitly 25128 this.model.validatorUrl = opts.swaggerOptions.validatorUrl; 25129 } else if (this.model.url.indexOf('localhost') > 0) { 25130 // Localhost override 25131 this.model.validatorUrl = null; 25132 } else { 25133 // Default validator 25134 if(window.location.protocol === 'https:') { 25135 this.model.validatorUrl = 'https://online.swagger.io/validator'; 25136 } 25137 else { 25138 this.model.validatorUrl = 'http://online.swagger.io/validator'; 25139 } 25140 } 25141 25142 // JSonEditor requires type='object' to be present on defined types, we add it if it's missing 25143 // is there any valid case were it should not be added ? 25144 var def; 25145 for(def in this.model.definitions){ 25146 if (!this.model.definitions[def].type){ 25147 this.model.definitions[def].type = 'object'; 25148 } 25149 } 25150 25151 }, 25152 25153 render: function(){ 25154 if (this.model.securityDefinitions) { 25155 for (var name in this.model.securityDefinitions) { 25156 var auth = this.model.securityDefinitions[name]; 25157 var button; 25158 25159 if (auth.type === 'apiKey' && $('#apikey_button').length === 0) { 25160 button = new SwaggerUi.Views.ApiKeyButton({model: auth, router: this.router}).render().el; 25161 $('.auth_main_container').append(button); 25162 } 25163 25164 if (auth.type === 'basicAuth' && $('#basic_auth_button').length === 0) { 25165 button = new SwaggerUi.Views.BasicAuthButton({model: auth, router: this.router}).render().el; 25166 $('.auth_main_container').append(button); 25167 } 25168 } 25169 } 25170 25171 // Render the outer container for resources 25172 $(this.el).html(Handlebars.templates.main(this.model)); 25173 25174 // Render each resource 25175 25176 var resources = {}; 25177 var counter = 0; 25178 for (var i = 0; i < this.model.apisArray.length; i++) { 25179 var resource = this.model.apisArray[i]; 25180 var id = resource.name; 25181 while (typeof resources[id] !== 'undefined') { 25182 id = id + '_' + counter; 25183 counter += 1; 25184 } 25185 resource.id = id; 25186 resources[id] = resource; 25187 this.addResource(resource, this.model.auths); 25188 } 25189 25190 $('.propWrap').hover(function onHover(){ 25191 $('.optionsWrapper', $(this)).show(); 25192 }, function offhover(){ 25193 $('.optionsWrapper', $(this)).hide(); 25194 }); 25195 return this; 25196 }, 25197 25198 addResource: function(resource, auths){ 25199 // Render a resource and add it to resources li 25200 resource.id = resource.id.replace(/\s/g, '_'); 25201 25202 // Make all definitions available at the root of the resource so that they can 25203 // be loaded by the JSonEditor 25204 resource.definitions = this.model.definitions; 25205 25206 var resourceView = new SwaggerUi.Views.ResourceView({ 25207 model: resource, 25208 router: this.router, 25209 tagName: 'li', 25210 id: 'resource_' + resource.id, 25211 className: 'resource', 25212 auths: auths, 25213 swaggerOptions: this.options.swaggerOptions 25214 }); 25215 $('#resources', this.el).append(resourceView.render().el); 25216 }, 25217 25218 clear: function(){ 25219 $(this.el).html(''); 25220 } 25221 }); 25222 25223 'use strict'; 25224 25225 SwaggerUi.Views.OperationView = Backbone.View.extend({ 25226 invocationUrl: null, 25227 25228 events: { 25229 'submit .sandbox' : 'submitOperation', 25230 'click .submit' : 'submitOperation', 25231 'click .response_hider' : 'hideResponse', 25232 'click .toggleOperation' : 'toggleOperationContent', 25233 'mouseenter .api-ic' : 'mouseEnter', 25234 'dblclick .curl' : 'selectText', 25235 }, 25236 25237 initialize: function(opts) { 25238 opts = opts || {}; 25239 this.router = opts.router; 25240 this.auths = opts.auths; 25241 this.parentId = this.model.parentId; 25242 this.nickname = this.model.nickname; 25243 this.model.encodedParentId = encodeURIComponent(this.parentId); 25244 25245 if (opts.swaggerOptions) { 25246 this.model.defaultRendering = opts.swaggerOptions.defaultModelRendering; 25247 25248 if (opts.swaggerOptions.showRequestHeaders) { 25249 this.model.showRequestHeaders = true; 25250 } 25251 } 25252 return this; 25253 }, 25254 25255 selectText: function(event) { 25256 var doc = document, 25257 text = event.target.firstChild, 25258 range, 25259 selection; 25260 if (doc.body.createTextRange) { 25261 range = document.body.createTextRange(); 25262 range.moveToElementText(text); 25263 range.select(); 25264 } else if (window.getSelection) { 25265 selection = window.getSelection(); 25266 range = document.createRange(); 25267 range.selectNodeContents(text); 25268 selection.removeAllRanges(); 25269 selection.addRange(range); 25270 } 25271 }, 25272 25273 mouseEnter: function(e) { 25274 var elem = $(this.el).find('.content'); 25275 var x = e.pageX; 25276 var y = e.pageY; 25277 var scX = $(window).scrollLeft(); 25278 var scY = $(window).scrollTop(); 25279 var scMaxX = scX + $(window).width(); 25280 var scMaxY = scY + $(window).height(); 25281 var wd = elem.width(); 25282 var hgh = elem.height(); 25283 25284 if (x + wd > scMaxX) { 25285 x = scMaxX - wd; 25286 } 25287 25288 if (x < scX) { 25289 x = scX; 25290 } 25291 25292 if (y + hgh > scMaxY) { 25293 y = scMaxY - hgh; 25294 } 25295 25296 if (y < scY) { 25297 y = scY; 25298 } 25299 25300 var pos = {}; 25301 pos.top = y; 25302 pos.left = x; 25303 elem.css(pos); 25304 }, 25305 25306 // Note: copied from CoffeeScript compiled file 25307 // TODO: redactor 25308 render: function() { 25309 var a, auth, auths, code, contentTypeModel, isMethodSubmissionSupported, k, key, l, len, len1, len2, len3, len4, m, modelAuths, n, o, p, param, q, ref, ref1, ref2, ref3, ref4, ref5, responseContentTypeView, responseSignatureView, schema, schemaObj, scopeIndex, signatureModel, statusCode, successResponse, type, v, value; 25310 isMethodSubmissionSupported = jQuery.inArray(this.model.method, this.model.supportedSubmitMethods()) >= 0; 25311 if (!isMethodSubmissionSupported) { 25312 this.model.isReadOnly = true; 25313 } 25314 this.model.description = this.model.description || this.model.notes; 25315 this.model.oauth = null; 25316 modelAuths = this.model.authorizations || this.model.security; 25317 if (modelAuths) { 25318 if (Array.isArray(modelAuths)) { 25319 for (l = 0, len = modelAuths.length; l < len; l++) { 25320 auths = modelAuths[l]; 25321 for (key in auths) { 25322 for (a in this.auths) { 25323 auth = this.auths[a]; 25324 if (key === auth.name) { 25325 if (auth.type === 'oauth2') { 25326 this.model.oauth = {}; 25327 this.model.oauth.scopes = []; 25328 ref1 = auth.value.scopes; 25329 for (k in ref1) { 25330 v = ref1[k]; 25331 scopeIndex = auths[key].indexOf(k); 25332 if (scopeIndex >= 0) { 25333 o = { 25334 scope: k, 25335 description: v 25336 }; 25337 this.model.oauth.scopes.push(o); 25338 } 25339 } 25340 } 25341 } 25342 } 25343 } 25344 } 25345 } else { 25346 for (k in modelAuths) { 25347 v = modelAuths[k]; 25348 if (k === 'oauth2') { 25349 if (this.model.oauth === null) { 25350 this.model.oauth = {}; 25351 } 25352 if (this.model.oauth.scopes === void 0) { 25353 this.model.oauth.scopes = []; 25354 } 25355 for (m = 0, len1 = v.length; m < len1; m++) { 25356 o = v[m]; 25357 this.model.oauth.scopes.push(o); 25358 } 25359 } 25360 } 25361 } 25362 } 25363 if (typeof this.model.responses !== 'undefined') { 25364 this.model.responseMessages = []; 25365 ref2 = this.model.responses; 25366 for (code in ref2) { 25367 value = ref2[code]; 25368 schema = null; 25369 schemaObj = this.model.responses[code].schema; 25370 if (schemaObj && schemaObj.$ref) { 25371 schema = schemaObj.$ref; 25372 if (schema.indexOf('#/definitions/') !== -1) { 25373 schema = schema.replace(/^.*#\/definitions\//, ''); 25374 } 25375 } 25376 this.model.responseMessages.push({ 25377 code: code, 25378 message: value.description, 25379 responseModel: schema, 25380 headers: value.headers 25381 }); 25382 } 25383 } 25384 if (typeof this.model.responseMessages === 'undefined') { 25385 this.model.responseMessages = []; 25386 } 25387 signatureModel = null; 25388 if (this.model.successResponse) { 25389 successResponse = this.model.successResponse; 25390 for (key in successResponse) { 25391 value = successResponse[key]; 25392 this.model.successCode = key; 25393 if (typeof value === 'object' && typeof value.createJSONSample === 'function') { 25394 this.model.successDescription = value.description; 25395 this.model.headers = this.parseResponseHeaders(value.headers); 25396 signatureModel = { 25397 sampleJSON: JSON.stringify(value.createJSONSample(), void 0, 2), 25398 isParam: false, 25399 signature: value.getMockSignature() 25400 }; 25401 } 25402 } 25403 } else if (this.model.responseClassSignature && this.model.responseClassSignature !== 'string') { 25404 signatureModel = { 25405 sampleJSON: this.model.responseSampleJSON, 25406 isParam: false, 25407 signature: this.model.responseClassSignature 25408 }; 25409 } 25410 $(this.el).html(Handlebars.templates.operation(this.model)); 25411 if (signatureModel) { 25412 signatureModel.defaultRendering = this.model.defaultRendering; 25413 responseSignatureView = new SwaggerUi.Views.SignatureView({ 25414 model: signatureModel, 25415 router: this.router, 25416 tagName: 'div' 25417 }); 25418 $('.model-signature', $(this.el)).append(responseSignatureView.render().el); 25419 } else { 25420 this.model.responseClassSignature = 'string'; 25421 $('.model-signature', $(this.el)).html(this.model.type); 25422 } 25423 contentTypeModel = { 25424 isParam: false 25425 }; 25426 contentTypeModel.consumes = this.model.consumes; 25427 contentTypeModel.produces = this.model.produces; 25428 ref3 = this.model.parameters; 25429 for (n = 0, len2 = ref3.length; n < len2; n++) { 25430 param = ref3[n]; 25431 type = param.type || param.dataType || ''; 25432 if (typeof type === 'undefined') { 25433 schema = param.schema; 25434 if (schema && schema.$ref) { 25435 ref = schema.$ref; 25436 if (ref.indexOf('#/definitions/') === 0) { 25437 type = ref.substring('#/definitions/'.length); 25438 } else { 25439 type = ref; 25440 } 25441 } 25442 } 25443 if (type && type.toLowerCase() === 'file') { 25444 if (!contentTypeModel.consumes) { 25445 contentTypeModel.consumes = 'multipart/form-data'; 25446 } 25447 } 25448 param.type = type; 25449 } 25450 responseContentTypeView = new SwaggerUi.Views.ResponseContentTypeView({ 25451 model: contentTypeModel, 25452 router: this.router 25453 }); 25454 $('.response-content-type', $(this.el)).append(responseContentTypeView.render().el); 25455 ref4 = this.model.parameters; 25456 for (p = 0, len3 = ref4.length; p < len3; p++) { 25457 param = ref4[p]; 25458 this.addParameter(param, contentTypeModel.consumes); 25459 } 25460 ref5 = this.model.responseMessages; 25461 for (q = 0, len4 = ref5.length; q < len4; q++) { 25462 statusCode = ref5[q]; 25463 this.addStatusCode(statusCode); 25464 } 25465 return this; 25466 }, 25467 25468 parseResponseHeaders: function (data) { 25469 var HEADERS_SEPARATOR = '; '; 25470 var headers = _.clone(data); 25471 25472 _.forEach(headers, function (header) { 25473 var other = []; 25474 _.forEach(header, function (value, key) { 25475 var properties = ['type', 'description']; 25476 if (properties.indexOf(key.toLowerCase()) === -1) { 25477 other.push(key + ': ' + value); 25478 } 25479 }); 25480 25481 other.join(HEADERS_SEPARATOR); 25482 header.other = other; 25483 }); 25484 25485 return headers; 25486 }, 25487 25488 addParameter: function(param, consumes) { 25489 // Render a parameter 25490 param.consumes = consumes; 25491 param.defaultRendering = this.model.defaultRendering; 25492 25493 // Copy this param JSON spec so that it will be available for JsonEditor 25494 if(param.schema){ 25495 $.extend(true, param.schema, this.model.definitions[param.type]); 25496 param.schema.definitions = this.model.definitions; 25497 // This is required for JsonEditor to display the root properly 25498 if(!param.schema.type){ 25499 param.schema.type = 'object'; 25500 } 25501 // This is the title that will be used by JsonEditor for the root 25502 // Since we already display the parameter's name in the Parameter column 25503 // We set this to space, we can't set it to null or space otherwise JsonEditor 25504 // will replace it with the text "root" which won't look good on screen 25505 if(!param.schema.title){ 25506 param.schema.title = ' '; 25507 } 25508 } 25509 25510 var paramView = new SwaggerUi.Views.ParameterView({ 25511 model: param, 25512 tagName: 'tr', 25513 readOnly: this.model.isReadOnly, 25514 swaggerOptions: this.options.swaggerOptions 25515 }); 25516 $('.operation-params', $(this.el)).append(paramView.render().el); 25517 }, 25518 25519 addStatusCode: function(statusCode) { 25520 // Render status codes 25521 statusCode.defaultRendering = this.model.defaultRendering; 25522 var statusCodeView = new SwaggerUi.Views.StatusCodeView({ 25523 model: statusCode, 25524 tagName: 'tr', 25525 router: this.router 25526 }); 25527 $('.operation-status', $(this.el)).append(statusCodeView.render().el); 25528 }, 25529 25530 // Note: copied from CoffeeScript compiled file 25531 // TODO: redactor 25532 submitOperation: function(e) { 25533 var error_free, form, isFileUpload, map, opts; 25534 if (e !== null) { 25535 e.preventDefault(); 25536 } 25537 form = $('.sandbox', $(this.el)); 25538 error_free = true; 25539 form.find('input.required').each(function() { 25540 $(this).removeClass('error'); 25541 if (jQuery.trim($(this).val()) === '') { 25542 $(this).addClass('error'); 25543 $(this).wiggle({ 25544 callback: (function(_this) { 25545 return function() { 25546 $(_this).focus(); 25547 }; 25548 })(this) 25549 }); 25550 error_free = false; 25551 } 25552 }); 25553 form.find('textarea.required:visible').each(function() { 25554 $(this).removeClass('error'); 25555 if (jQuery.trim($(this).val()) === '') { 25556 $(this).addClass('error'); 25557 $(this).wiggle({ 25558 callback: (function(_this) { 25559 return function() { 25560 return $(_this).focus(); 25561 }; 25562 })(this) 25563 }); 25564 error_free = false; 25565 } 25566 }); 25567 form.find('select.required').each(function() { 25568 $(this).removeClass('error'); 25569 if (this.selectedIndex === -1) { 25570 $(this).addClass('error'); 25571 $(this).wiggle({ 25572 callback: (function(_this) { 25573 return function() { 25574 $(_this).focus(); 25575 }; 25576 })(this) 25577 }); 25578 error_free = false; 25579 } 25580 }); 25581 if (error_free) { 25582 map = this.getInputMap(form); 25583 isFileUpload = this.isFileUpload(form); 25584 opts = { 25585 parent: this 25586 }; 25587 if (this.options.swaggerOptions) { 25588 for(var key in this.options.swaggerOptions) { 25589 opts[key] = this.options.swaggerOptions[key]; 25590 } 25591 } 25592 25593 var pi; 25594 for(pi = 0; pi < this.model.parameters.length; pi++){ 25595 var p = this.model.parameters[pi]; 25596 if( p.jsonEditor && p.jsonEditor.isEnabled()){ 25597 var json = p.jsonEditor.getValue(); 25598 map[p.name] = JSON.stringify(json); 25599 } 25600 } 25601 25602 opts.responseContentType = $('div select[name=responseContentType]', $(this.el)).val(); 25603 opts.requestContentType = $('div select[name=parameterContentType]', $(this.el)).val(); 25604 $('.response_throbber', $(this.el)).show(); 25605 if (isFileUpload) { 25606 $('.request_url', $(this.el)).html('<pre></pre>'); 25607 $('.request_url pre', $(this.el)).text(this.invocationUrl); 25608 25609 opts.useJQuery = true; 25610 map.parameterContentType = 'multipart/form-data'; 25611 this.map = map; 25612 return this.model.execute(map, opts, this.showCompleteStatus, this.showErrorStatus, this); 25613 } else { 25614 this.map = map; 25615 return this.model.execute(map, opts, this.showCompleteStatus, this.showErrorStatus, this); 25616 } 25617 } 25618 }, 25619 25620 getInputMap: function (form) { 25621 var map, ref1, l, len, o, ref2, m, len1, val, ref3, n, len2; 25622 map = {}; 25623 ref1 = form.find('input'); 25624 for (l = 0, len = ref1.length; l < len; l++) { 25625 o = ref1[l]; 25626 if ((o.value !== null) && jQuery.trim(o.value).length > 0) { 25627 map[o.name] = o.value; 25628 } 25629 if (o.type === 'file') { 25630 map[o.name] = o.files[0]; 25631 } 25632 } 25633 ref2 = form.find('textarea'); 25634 for (m = 0, len1 = ref2.length; m < len1; m++) { 25635 o = ref2[m]; 25636 val = this.getTextAreaValue(o); 25637 if ((val !== null) && jQuery.trim(val).length > 0) { 25638 map[o.name] = val; 25639 } 25640 } 25641 ref3 = form.find('select'); 25642 for (n = 0, len2 = ref3.length; n < len2; n++) { 25643 o = ref3[n]; 25644 val = this.getSelectedValue(o); 25645 if ((val !== null) && jQuery.trim(val).length > 0) { 25646 map[o.name] = val; 25647 } 25648 } 25649 return map; 25650 }, 25651 25652 isFileUpload: function (form) { 25653 var ref1, l, len, o; 25654 var isFileUpload = false; 25655 ref1 = form.find('input'); 25656 for (l = 0, len = ref1.length; l < len; l++) { 25657 o = ref1[l]; 25658 if (o.type === 'file') { 25659 isFileUpload = true; 25660 } 25661 } 25662 return isFileUpload; 25663 }, 25664 25665 success: function(response, parent) { 25666 parent.showCompleteStatus(response); 25667 }, 25668 25669 // wraps a jquery response as a shred response 25670 wrap: function(data) { 25671 var h, headerArray, headers, i, l, len, o; 25672 headers = {}; 25673 headerArray = data.getAllResponseHeaders().split('\r'); 25674 for (l = 0, len = headerArray.length; l < len; l++) { 25675 i = headerArray[l]; 25676 h = i.match(/^([^:]*?):(.*)$/); 25677 if (!h) { 25678 h = []; 25679 } 25680 h.shift(); 25681 if (h[0] !== void 0 && h[1] !== void 0) { 25682 headers[h[0].trim()] = h[1].trim(); 25683 } 25684 } 25685 o = {}; 25686 o.content = {}; 25687 o.content.data = data.responseText; 25688 o.headers = headers; 25689 o.request = {}; 25690 o.request.url = this.invocationUrl; 25691 o.status = data.status; 25692 return o; 25693 }, 25694 25695 getSelectedValue: function(select) { 25696 if (!select.multiple) { 25697 return select.value; 25698 } else { 25699 var options = []; 25700 for (var l = 0, len = select.options.length; l < len; l++) { 25701 var opt = select.options[l]; 25702 if (opt.selected) { 25703 options.push(opt.value); 25704 } 25705 } 25706 if (options.length > 0) { 25707 return options; 25708 } else { 25709 return null; 25710 } 25711 } 25712 }, 25713 25714 // handler for hide response link 25715 hideResponse: function(e) { 25716 if (e) { e.preventDefault(); } 25717 $('.response', $(this.el)).slideUp(); 25718 $('.response_hider', $(this.el)).fadeOut(); 25719 }, 25720 25721 // Show response from server 25722 showResponse: function(response) { 25723 var prettyJson = JSON.stringify(response, null, '\t').replace(/\n/g, '<br>'); 25724 $('.response_body', $(this.el)).html(_.escape(prettyJson)); 25725 }, 25726 25727 // Show error from server 25728 showErrorStatus: function(data, parent) { 25729 parent.showStatus(data); 25730 }, 25731 25732 // show the status codes 25733 showCompleteStatus: function(data, parent){ 25734 parent.showStatus(data); 25735 }, 25736 25737 // Adapted from http://stackoverflow.com/a/2893259/454004 25738 // Note: directly ported from CoffeeScript 25739 // TODO: Cleanup CoffeeScript artifacts 25740 formatXml: function(xml) { 25741 var contexp, fn, formatted, indent, l, lastType, len, lines, ln, pad, reg, transitions, wsexp; 25742 reg = /(>)(<)(\/*)/g; 25743 wsexp = /[ ]*(.*)[ ]+\n/g; 25744 contexp = /(<.+>)(.+\n)/g; 25745 xml = xml.replace(reg, '$1\n$2$3').replace(wsexp, '$1\n').replace(contexp, '$1\n$2'); 25746 pad = 0; 25747 formatted = ''; 25748 lines = xml.split('\n'); 25749 indent = 0; 25750 lastType = 'other'; 25751 transitions = { 25752 'single->single': 0, 25753 'single->closing': -1, 25754 'single->opening': 0, 25755 'single->other': 0, 25756 'closing->single': 0, 25757 'closing->closing': -1, 25758 'closing->opening': 0, 25759 'closing->other': 0, 25760 'opening->single': 1, 25761 'opening->closing': 0, 25762 'opening->opening': 1, 25763 'opening->other': 1, 25764 'other->single': 0, 25765 'other->closing': -1, 25766 'other->opening': 0, 25767 'other->other': 0 25768 }; 25769 fn = function(ln) { 25770 var fromTo, j, key, padding, type, types, value; 25771 types = { 25772 single: Boolean(ln.match(/<.+\/>/)), 25773 closing: Boolean(ln.match(/<\/.+>/)), 25774 opening: Boolean(ln.match(/<[^!?].*>/)) 25775 }; 25776 type = ((function() { 25777 var results; 25778 results = []; 25779 for (key in types) { 25780 value = types[key]; 25781 if (value) { 25782 results.push(key); 25783 } 25784 } 25785 return results; 25786 })())[0]; 25787 type = type === void 0 ? 'other' : type; 25788 fromTo = lastType + '->' + type; 25789 lastType = type; 25790 padding = ''; 25791 indent += transitions[fromTo]; 25792 padding = ((function() { 25793 var m, ref1, results; 25794 results = []; 25795 for (j = m = 0, ref1 = indent; 0 <= ref1 ? m < ref1 : m > ref1; j = 0 <= ref1 ? ++m : --m) { 25796 results.push(' '); 25797 } 25798 return results; 25799 })()).join(''); 25800 if (fromTo === 'opening->closing') { 25801 formatted = formatted.substr(0, formatted.length - 1) + ln + '\n'; 25802 } else { 25803 formatted += padding + ln + '\n'; 25804 } 25805 }; 25806 for (l = 0, len = lines.length; l < len; l++) { 25807 ln = lines[l]; 25808 fn(ln); 25809 } 25810 return formatted; 25811 }, 25812 25813 // puts the response data in UI 25814 showStatus: function(response) { 25815 var url, content; 25816 if (response.content === undefined) { 25817 content = response.data; 25818 url = response.url; 25819 } else { 25820 content = response.content.data; 25821 url = response.request.url; 25822 } 25823 var headers = response.headers; 25824 content = jQuery.trim(content); 25825 25826 // if server is nice, and sends content-type back, we can use it 25827 var contentType = null; 25828 if (headers) { 25829 contentType = headers['Content-Type'] || headers['content-type']; 25830 if (contentType) { 25831 contentType = contentType.split(';')[0].trim(); 25832 } 25833 } 25834 $('.response_body', $(this.el)).removeClass('json'); 25835 $('.response_body', $(this.el)).removeClass('xml'); 25836 25837 var supportsAudioPlayback = function(contentType){ 25838 var audioElement = document.createElement('audio'); 25839 return !!(audioElement.canPlayType && audioElement.canPlayType(contentType).replace(/no/, '')); 25840 }; 25841 25842 var pre; 25843 var code; 25844 if (!content) { 25845 code = $('<code />').text('no content'); 25846 pre = $('<pre class="json" />').append(code); 25847 25848 // JSON 25849 } else if (contentType === 'application/json' || /\+json$/.test(contentType)) { 25850 var json = null; 25851 try { 25852 json = JSON.stringify(JSON.parse(content), null, ' '); 25853 } catch (_error) { 25854 json = 'can\'t parse JSON. Raw result:\n\n' + content; 25855 } 25856 code = $('<code />').text(json); 25857 pre = $('<pre class="json" />').append(code); 25858 25859 // XML 25860 } else if (contentType === 'application/xml' || /\+xml$/.test(contentType)) { 25861 code = $('<code />').text(this.formatXml(content)); 25862 pre = $('<pre class="xml" />').append(code); 25863 25864 // HTML 25865 } else if (contentType === 'text/html') { 25866 code = $('<code />').html(_.escape(content)); 25867 pre = $('<pre class="xml" />').append(code); 25868 25869 // Plain Text 25870 } else if (/text\/plain/.test(contentType)) { 25871 code = $('<code />').text(content); 25872 pre = $('<pre class="plain" />').append(code); 25873 25874 25875 // Image 25876 } else if (/^image\//.test(contentType)) { 25877 pre = $('<img>').attr('src', url); 25878 25879 // Audio 25880 } else if (/^audio\//.test(contentType) && supportsAudioPlayback(contentType)) { 25881 pre = $('<audio controls>').append($('<source>').attr('src', url).attr('type', contentType)); 25882 25883 // Download 25884 } else if (headers['Content-Disposition'] && (/attachment/).test(headers['Content-Disposition']) || 25885 headers['content-disposition'] && (/attachment/).test(headers['content-disposition']) || 25886 headers['Content-Description'] && (/File Transfer/).test(headers['Content-Description']) || 25887 headers['content-description'] && (/File Transfer/).test(headers['content-description'])) { 25888 25889 if ('Blob' in window) { 25890 var type = contentType || 'text/html'; 25891 var blob = new Blob([content], {type: type}); 25892 var a = document.createElement('a'); 25893 var href = window.URL.createObjectURL(blob); 25894 var fileName = response.url.substr(response.url.lastIndexOf('/') + 1); 25895 var download = [type, fileName, href].join(':'); 25896 25897 a.setAttribute('href', href); 25898 a.setAttribute('download', download); 25899 a.innerText = 'Download ' + fileName; 25900 25901 pre = $('<div/>').append(a); 25902 } else { 25903 pre = $('<pre class="json" />').append('Download headers detected but your browser does not support downloading binary via XHR (Blob).'); 25904 } 25905 25906 // Location header based redirect download 25907 } else if(headers.location || headers.Location) { 25908 window.location = response.url; 25909 25910 // Anything else (CORS) 25911 } else { 25912 code = $('<code />').text(content); 25913 pre = $('<pre class="json" />').append(code); 25914 } 25915 var response_body = pre; 25916 $('.request_url', $(this.el)).html('<pre></pre>'); 25917 $('.request_url pre', $(this.el)).text(url); 25918 $('.response_code', $(this.el)).html('<pre>' + response.status + '</pre>'); 25919 $('.response_body', $(this.el)).html(response_body); 25920 $('.response_headers', $(this.el)).html('<pre>' + _.escape(JSON.stringify(response.headers, null, ' ')).replace(/\n/g, '<br>') + '</pre>'); 25921 $('.response', $(this.el)).slideDown(); 25922 $('.response_hider', $(this.el)).show(); 25923 $('.response_throbber', $(this.el)).hide(); 25924 25925 25926 // adds curl output 25927 var curlCommand = this.model.asCurl(this.map, {responseContentType: contentType}); 25928 curlCommand = curlCommand.replace('!', '!'); 25929 $( 'div.curl', $(this.el)).html('<pre>' + curlCommand + '</pre>'); 25930 25931 // only highlight the response if response is less than threshold, default state is highlight response 25932 var opts = this.options.swaggerOptions; 25933 25934 if (opts.showRequestHeaders) { 25935 var form = $('.sandbox', $(this.el)), 25936 map = this.getInputMap(form), 25937 requestHeaders = this.model.getHeaderParams(map); 25938 delete requestHeaders['Content-Type']; 25939 $('.request_headers', $(this.el)).html('<pre>' + _.escape(JSON.stringify(requestHeaders, null, ' ')).replace(/\n/g, '<br>') + '</pre>'); 25940 } 25941 25942 var response_body_el = $('.response_body', $(this.el))[0]; 25943 // only highlight the response if response is less than threshold, default state is highlight response 25944 if (opts.highlightSizeThreshold && typeof response.data !== 'undefined' && response.data.length > opts.highlightSizeThreshold) { 25945 return response_body_el; 25946 } else { 25947 return hljs.highlightBlock(response_body_el); 25948 } 25949 }, 25950 25951 toggleOperationContent: function (event) { 25952 var elem = $('#' + Docs.escapeResourceName(this.parentId + '_' + this.nickname + '_content')); 25953 if (elem.is(':visible')){ 25954 $.bbq.pushState('#/', 2); 25955 event.preventDefault(); 25956 Docs.collapseOperation(elem); 25957 } else { 25958 Docs.expandOperation(elem); 25959 } 25960 }, 25961 25962 getTextAreaValue: function(textArea) { 25963 var param, parsed, result, i; 25964 if (textArea.value === null || jQuery.trim(textArea.value).length === 0) { 25965 return null; 25966 } 25967 param = this.getParamByName(textArea.name); 25968 if (param && param.type && param.type.toLowerCase() === 'array') { 25969 parsed = textArea.value.split('\n'); 25970 result = []; 25971 for (i = 0; i < parsed.length; i++) { 25972 if (parsed[i] !== null && jQuery.trim(parsed[i]).length > 0) { 25973 result.push(parsed[i]); 25974 } 25975 } 25976 return result.length > 0 ? result : null; 25977 } else { 25978 return textArea.value; 25979 } 25980 }, 25981 25982 getParamByName: function(name) { 25983 var i; 25984 if (this.model.parameters) { 25985 for(i = 0; i < this.model.parameters.length; i++) { 25986 if (this.model.parameters[i].name === name) { 25987 return this.model.parameters[i]; 25988 } 25989 } 25990 } 25991 return null; 25992 } 25993 25994 }); 25995 25996 'use strict'; 25997 25998 SwaggerUi.Views.ParameterContentTypeView = Backbone.View.extend({ 25999 initialize: function () {}, 26000 26001 render: function(){ 26002 this.model.parameterContentTypeId = 'pct' + Math.random(); 26003 $(this.el).html(Handlebars.templates.parameter_content_type(this.model)); 26004 return this; 26005 } 26006 26007 }); 26008 'use strict'; 26009 26010 SwaggerUi.Views.ParameterView = Backbone.View.extend({ 26011 initialize: function(){ 26012 Handlebars.registerHelper('isArray', function(param, opts) { 26013 if (param.type.toLowerCase() === 'array' || param.allowMultiple) { 26014 return opts.fn(this); 26015 } else { 26016 return opts.inverse(this); 26017 } 26018 }); 26019 }, 26020 26021 render: function() { 26022 var type = this.model.type || this.model.dataType; 26023 26024 if (typeof type === 'undefined') { 26025 var schema = this.model.schema; 26026 if (schema && schema.$ref) { 26027 var ref = schema.$ref; 26028 if (ref.indexOf('#/definitions/') === 0) { 26029 type = ref.substring('#/definitions/'.length); 26030 } else { 26031 type = ref; 26032 } 26033 } 26034 } 26035 26036 this.model.type = type; 26037 this.model.paramType = this.model.in || this.model.paramType; 26038 this.model.isBody = this.model.paramType === 'body' || this.model.in === 'body'; 26039 this.model.isFile = type && type.toLowerCase() === 'file'; 26040 26041 // Allow for default === false 26042 if(typeof this.model.default === 'undefined') { 26043 this.model.default = this.model.defaultValue; 26044 } 26045 26046 this.model.hasDefault = (typeof this.model.default !== 'undefined'); 26047 this.model.valueId = 'm' + this.model.name + Math.random(); 26048 26049 if (this.model.allowableValues) { 26050 this.model.isList = true; 26051 } 26052 26053 var template = this.template(); 26054 $(this.el).html(template(this.model)); 26055 26056 var signatureModel = { 26057 sampleJSON: this.model.sampleJSON, 26058 isParam: true, 26059 signature: this.model.signature, 26060 defaultRendering: this.model.defaultRendering 26061 }; 26062 26063 if (this.model.sampleJSON) { 26064 var signatureView = new SwaggerUi.Views.SignatureView({model: signatureModel, tagName: 'div'}); 26065 $('.model-signature', $(this.el)).append(signatureView.render().el); 26066 } 26067 else { 26068 $('.model-signature', $(this.el)).html(this.model.signature); 26069 } 26070 26071 var isParam = false; 26072 26073 if( this.options.swaggerOptions.jsonEditor && this.model.isBody && this.model.schema){ 26074 var $self = $(this.el); 26075 this.model.jsonEditor = 26076 /* global JSONEditor */ 26077 new JSONEditor($('.editor_holder', $self)[0], 26078 {schema: this.model.schema, startval : this.model.default, 26079 ajax:true, 26080 disable_properties:true, 26081 disable_edit_json:true, 26082 iconlib: 'swagger' }); 26083 // This is so that the signature can send back the sample to the json editor 26084 // TODO: SignatureView should expose an event "onSampleClicked" instead 26085 signatureModel.jsonEditor = this.model.jsonEditor; 26086 $('.body-textarea', $self).hide(); 26087 $('.editor_holder', $self).show(); 26088 $('.parameter-content-type', $self) 26089 .change(function(e){ 26090 if(e.target.value === 'application/xml'){ 26091 $('.body-textarea', $self).show(); 26092 $('.editor_holder', $self).hide(); 26093 this.model.jsonEditor.disable(); 26094 } 26095 else { 26096 $('.body-textarea', $self).hide(); 26097 $('.editor_holder', $self).show(); 26098 this.model.jsonEditor.enable(); 26099 } 26100 }); 26101 } 26102 26103 26104 if (this.model.isBody) { 26105 isParam = true; 26106 } 26107 26108 var contentTypeModel = { 26109 isParam: isParam 26110 }; 26111 26112 contentTypeModel.consumes = this.model.consumes; 26113 26114 if (isParam) { 26115 var parameterContentTypeView = new SwaggerUi.Views.ParameterContentTypeView({model: contentTypeModel}); 26116 $('.parameter-content-type', $(this.el)).append(parameterContentTypeView.render().el); 26117 } 26118 26119 else { 26120 var responseContentTypeView = new SwaggerUi.Views.ResponseContentTypeView({model: contentTypeModel}); 26121 $('.response-content-type', $(this.el)).append(responseContentTypeView.render().el); 26122 } 26123 26124 return this; 26125 }, 26126 26127 // Return an appropriate template based on if the parameter is a list, readonly, required 26128 template: function(){ 26129 if (this.model.isList) { 26130 return Handlebars.templates.param_list; 26131 } else { 26132 if (this.options.readOnly) { 26133 if (this.model.required) { 26134 return Handlebars.templates.param_readonly_required; 26135 } else { 26136 return Handlebars.templates.param_readonly; 26137 } 26138 } else { 26139 if (this.model.required) { 26140 return Handlebars.templates.param_required; 26141 } else { 26142 return Handlebars.templates.param; 26143 } 26144 } 26145 } 26146 } 26147 }); 26148 26149 'use strict'; 26150 26151 SwaggerUi.Views.ResourceView = Backbone.View.extend({ 26152 initialize: function(opts) { 26153 opts = opts || {}; 26154 this.router = opts.router; 26155 this.auths = opts.auths; 26156 if ('' === this.model.description) { 26157 this.model.description = null; 26158 } 26159 if (this.model.description) { 26160 this.model.summary = this.model.description; 26161 } 26162 }, 26163 26164 render: function(){ 26165 var methods = {}; 26166 26167 26168 $(this.el).html(Handlebars.templates.resource(this.model)); 26169 26170 // Render each operation 26171 for (var i = 0; i < this.model.operationsArray.length; i++) { 26172 var operation = this.model.operationsArray[i]; 26173 var counter = 0; 26174 var id = operation.nickname; 26175 26176 while (typeof methods[id] !== 'undefined') { 26177 id = id + '_' + counter; 26178 counter += 1; 26179 } 26180 26181 methods[id] = operation; 26182 26183 operation.nickname = id; 26184 operation.parentId = this.model.id; 26185 operation.definitions = this.model.definitions; // make Json Schema available for JSonEditor in this operation 26186 this.addOperation(operation); 26187 } 26188 26189 $('.toggleEndpointList', this.el).click(this.callDocs.bind(this, 'toggleEndpointListForResource')); 26190 $('.collapseResource', this.el).click(this.callDocs.bind(this, 'collapseOperationsForResource')); 26191 $('.expandResource', this.el).click(this.callDocs.bind(this, 'expandOperationsForResource')); 26192 26193 return this; 26194 }, 26195 26196 addOperation: function(operation) { 26197 26198 operation.number = this.number; 26199 26200 // Render an operation and add it to operations li 26201 var operationView = new SwaggerUi.Views.OperationView({ 26202 model: operation, 26203 router: this.router, 26204 tagName: 'li', 26205 className: 'endpoint', 26206 swaggerOptions: this.options.swaggerOptions, 26207 auths: this.auths 26208 }); 26209 26210 $('.endpoints', $(this.el)).append(operationView.render().el); 26211 26212 this.number++; 26213 26214 }, 26215 // Generic Event handler (`Docs` is global) 26216 26217 26218 callDocs: function(fnName, e) { 26219 e.preventDefault(); 26220 Docs[fnName](e.currentTarget.getAttribute('data-id')); 26221 } 26222 }); 26223 'use strict'; 26224 26225 SwaggerUi.Views.ResponseContentTypeView = Backbone.View.extend({ 26226 initialize: function(){}, 26227 26228 render: function(){ 26229 this.model.responseContentTypeId = 'rct' + Math.random(); 26230 $(this.el).html(Handlebars.templates.response_content_type(this.model)); 26231 return this; 26232 } 26233 }); 26234 'use strict'; 26235 26236 SwaggerUi.Views.SignatureView = Backbone.View.extend({ 26237 events: { 26238 'click a.description-link' : 'switchToDescription', 26239 'click a.snippet-link' : 'switchToSnippet', 26240 'mousedown .snippet' : 'snippetToTextArea' 26241 }, 26242 26243 initialize: function () { 26244 26245 }, 26246 26247 render: function(){ 26248 26249 $(this.el).html(Handlebars.templates.signature(this.model)); 26250 26251 if (this.model.defaultRendering === 'model') { 26252 this.switchToDescription(); 26253 } else { 26254 this.switchToSnippet(); 26255 } 26256 26257 this.isParam = this.model.isParam; 26258 26259 if (this.isParam) { 26260 $('.notice', $(this.el)).text('Click to set as parameter value'); 26261 } 26262 26263 return this; 26264 }, 26265 26266 // handler for show signature 26267 switchToDescription: function(e){ 26268 if (e) { e.preventDefault(); } 26269 26270 $('.snippet', $(this.el)).hide(); 26271 $('.description', $(this.el)).show(); 26272 $('.description-link', $(this.el)).addClass('selected'); 26273 $('.snippet-link', $(this.el)).removeClass('selected'); 26274 }, 26275 26276 // handler for show sample 26277 switchToSnippet: function(e){ 26278 if (e) { e.preventDefault(); } 26279 26280 $('.description', $(this.el)).hide(); 26281 $('.snippet', $(this.el)).show(); 26282 $('.snippet-link', $(this.el)).addClass('selected'); 26283 $('.description-link', $(this.el)).removeClass('selected'); 26284 }, 26285 26286 // handler for snippet to text area 26287 snippetToTextArea: function(e) { 26288 if (this.isParam) { 26289 if (e) { e.preventDefault(); } 26290 26291 var textArea = $('textarea', $(this.el.parentNode.parentNode.parentNode)); 26292 26293 // Fix for bug in IE 10/11 which causes placeholder text to be copied to "value" 26294 if ($.trim(textArea.val()) === '' || textArea.prop('placeholder') === textArea.val()) { 26295 textArea.val(this.model.sampleJSON); 26296 // TODO move this code outside of the view and expose an event instead 26297 if( this.model.jsonEditor && this.model.jsonEditor.isEnabled()){ 26298 this.model.jsonEditor.setValue(JSON.parse(this.model.sampleJSON)); 26299 } 26300 } 26301 } 26302 } 26303 }); 26304 'use strict'; 26305 26306 SwaggerUi.Views.StatusCodeView = Backbone.View.extend({ 26307 initialize: function (opts) { 26308 this.options = opts || {}; 26309 this.router = this.options.router; 26310 }, 26311 26312 render: function(){ 26313 $(this.el).html(Handlebars.templates.status_code(this.model)); 26314 26315 if (this.router.api.models.hasOwnProperty(this.model.responseModel)) { 26316 var responseModel = { 26317 sampleJSON: JSON.stringify(this.router.api.models[this.model.responseModel].createJSONSample(), null, 2), 26318 isParam: false, 26319 signature: this.router.api.models[this.model.responseModel].getMockSignature(), 26320 defaultRendering: this.model.defaultRendering 26321 }; 26322 26323 var responseModelView = new SwaggerUi.Views.SignatureView({model: responseModel, tagName: 'div'}); 26324 $('.model-signature', this.$el).append(responseModelView.render().el); 26325 } else { 26326 $('.model-signature', this.$el).html(''); 26327 } 26328 return this; 26329 } 26330 });}).call(this);